home *** CD-ROM | disk | FTP | other *** search
Unknown | 1999-04-07 | 30.0 KB | [TgPj/RBv2] |
open in:
MacOS 8.1
|
Win98
|
DOS
view JSON data
|
view as text
This file was not able to be converted.
This format is not currently supported by dexvert.
Confidence | Program | Detection | Match Type | Support
|
---|
100%
| file
| data
| default
|
|
id metadata |
---|
key | value |
---|
macFileType | [TgPj] |
macFileCreator | [RBv2] |
hex view+--------+-------------------------+-------------------------+--------+--------+
|00000000| 0b 0c 00 01 41 41 41 41 | 41 41 41 41 41 41 41 41 |....AAAA|AAAAAAAA|
|00000010| 41 41 41 41 01 04 3f 3f | 3f 3f 00 00 01 01 00 00 |AAAA..??|??......|
|00000020| 07 41 70 70 4e 61 6d 65 | 80 80 80 01 80 80 80 01 |.AppName|........|
|00000030| 01 00 00 00 00 00 00 00 | 02 49 43 4e 23 80 04 00 |........|.ICN#...|
|00000040| 01 80 00 00 06 60 00 00 | 18 18 00 00 60 06 00 00 |.....`..|....`...|
|00000050| 48 0a 00 00 42 22 00 00 | 40 8a 00 00 40 22 00 00 |H...B"..|@...@"..|
|00000060| 40 8a 00 00 40 22 00 00 | 40 8a 00 00 60 26 00 01 |@...@"..|@...`&..|
|00000070| 98 99 80 06 06 60 60 18 | 01 80 18 12 02 20 28 10 |.....``.|..... (.|
|00000080| 88 88 88 10 22 02 28 30 | 08 80 8c 70 22 02 2a 90 |....".(0|...p".*.|
|00000090| 08 80 8d b0 22 02 2b 98 | 09 80 99 a6 26 62 67 69 |....".+.|....&bgi|
|000000a0| 98 19 9e 1a 60 06 78 06 | 80 01 e0 01 a0 07 80 00 |....`.x.|........|
|000000b0| 68 1e 00 00 1a 78 00 00 | 06 e0 00 00 01 80 00 00 |h....x..|........|
|000000c0| 01 80 00 00 07 e0 00 00 | 1f f8 00 00 7f fe 00 00 |........|........|
|000000d0| 7f fe 00 00 7f fe 00 00 | 7f fe 00 00 7f fe 00 00 |........|........|
|000000e0| 7f fe 00 00 7f fe 00 00 | 7f fe 00 00 7f fe 00 01 |........|........|
|000000f0| ff ff 80 07 ff ff e0 1f | ff ff f8 1f ff ff f8 1f |........|........|
|00000100| ff ff f8 1f ff ff f8 3f | ff ff fc 7f ff ff fe ff |.......?|........|
|00000110| ff ff ff ff ff ff ff ff | ff ff ff ff ff ff ff 7f |........|........|
|00000120| ff ff fe 1f ff ff f8 07 | ff ff e0 01 ff ff 80 00 |........|........|
|00000130| 7f fe 00 00 1f f8 00 00 | 07 e0 00 00 01 80 00 69 |........|.......i|
|00000140| 63 6c 38 80 10 00 00 00 | 00 00 00 00 00 00 00 00 |cl8.....|........|
|00000150| 00 00 00 00 ff ff 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000160| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000170| 00 00 ff ff e1 e1 ff ff | 00 00 00 00 00 00 00 00 |........|........|
|00000180| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000190| ff ff e1 e1 e1 e1 e1 e1 | ff ff 00 00 00 00 00 00 |........|........|
|000001a0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 ff ff |........|........|
|000001b0| e1 e1 e1 e1 e1 e1 e1 e1 | e1 e1 ff ff 00 00 00 00 |........|........|
|000001c0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 ff e3 |........|........|
|000001d0| e3 00 e1 e1 e1 e1 e1 e1 | e1 e3 e5 ff 00 00 00 00 |........|........|
|000001e0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 ff e3 |........|........|
|000001f0| e3 e3 e3 00 e1 e1 e1 e3 | e5 e5 e5 ff 00 00 00 00 |........|........|
|00000200| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 ff e3 |........|........|
|00000210| e3 e3 e3 e3 e3 00 e5 e5 | e5 e5 e5 ff 00 00 00 00 |........|........|
|00000220| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 ff e3 |........|........|
|00000230| e3 e3 e3 e3 e3 e5 e5 e5 | e5 e5 e5 ff 00 00 00 00 |........|........|
|00000240| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 ff e3 |........|........|
|00000250| e3 e3 e3 e3 e3 e3 e5 e5 | e5 e5 e5 ff 00 00 00 00 |........|........|
|00000260| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 ff e3 |........|........|
|00000270| e3 e3 e3 e3 e3 e5 e5 e5 | e5 e5 e5 ff 00 00 00 00 |........|........|
|00000280| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 ff e3 |........|........|
|00000290| e3 e3 e3 e3 e3 e3 e5 e5 | e5 e5 e5 ff 00 00 00 00 |........|........|
|000002a0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 ff e3 |........|........|
|000002b0| e3 e3 e3 e3 e3 e5 e5 e5 | e5 e5 e5 ff 00 00 00 00 |........|........|
|000002c0| 00 00 00 00 00 00 00 00 | 00 00 00 00 ff ff 2a 2a |........|......**|
|000002d0| e3 e3 e3 e3 e3 e3 e5 e5 | e5 e5 0b 0b ff ff 00 00 |........|........|
|000002e0| 00 00 00 00 00 00 00 00 | 00 00 ff ff 2a 2a 2a 2a |........|....****|
|000002f0| 2a 2a e3 e3 e3 e5 e5 e5 | 0b 0b 0b 0b 0b 0b ff ff |**......|........|
|00000300| 00 00 00 00 00 00 00 00 | ff ff 2a 2a 2a 2a 2a 2a |........|..******|
|00000310| 2a 2a 2a 2a 2a 54 0b 0b | 0b 0b 0b 0b 0b 0b 0b 0b |*****T..|........|
|00000320| ff ff 00 00 00 00 00 00 | ff 54 54 00 2a 2a 2a 2a |........|.TT.****|
|00000330| 2a 2a 2a 54 7f 11 11 00 | 0b 0b 0b 0b 0b 0b 0b 11 |***T....|........|
|00000340| 17 ff 00 00 00 00 00 00 | ff 54 54 54 54 00 2a 2a |........|.TTTT.**|
|00000350| 2a 54 7f 7f 7f 7f 11 11 | 11 00 0b 0b 0b 11 17 17 |*T......|........|
|00000360| 17 ff 00 00 00 00 00 00 | ff 54 54 54 54 54 54 00 |........|.TTTTTT.|
|00000370| 7f 7f 7f 7f 7f 11 11 11 | 11 11 11 00 17 17 17 17 |........|........|
|00000380| 17 ff 00 00 00 00 00 ff | ff 54 54 54 54 54 54 7f |........|.TTTTTT.|
|00000390| 7f 7f 7f 7f 7f 7f 11 11 | 11 11 11 17 17 17 17 17 |........|........|
|000003a0| 17 ff ff 00 00 00 ff 00 | ff 54 54 54 54 54 54 54 |........|.TTTTTTT|
|000003b0| 7f 7f 7f 7f 7f 11 11 11 | 11 11 11 11 17 17 17 17 |........|........|
|000003c0| 17 ff f9 ff 00 ff 00 f7 | ff 54 54 54 54 54 54 7f |........|.TTTTTT.|
|000003d0| 7f 7f 7f 7f 7f 7f 11 11 | 11 11 11 17 17 17 17 17 |........|........|
|000003e0| 17 ff f7 f9 ff ff f7 f7 | ff 54 54 54 54 54 54 54 |........|.TTTTTTT|
|000003f0| 7f 7f 7f 7f 7f 11 11 11 | 11 11 11 11 17 17 17 17 |........|........|
|00000400| 17 ff f7 f7 ff ff f7 00 | ff ff 54 54 54 54 54 7f |........|..TTTTT.|
|00000410| 7f 7f 7f 7f ff ff 11 11 | 11 11 11 17 17 17 17 17 |........|........|
|00000420| ff ff f7 f9 ff ff f7 f7 | f7 00 ff ff 54 54 54 54 |........|....TTTT|
|00000430| 7f 7f ff ff f9 f9 ff ff | 11 11 11 11 17 17 ff ff |........|........|
|00000440| f7 f9 f9 f9 ff 00 ff ff | f7 f7 f7 00 ff ff 54 7f |........|......T.|
|00000450| ff ff f9 f9 f9 f9 f7 f6 | ff ff 11 17 ff ff f7 f9 |........|........|
|00000460| f9 f9 ff ff 00 00 00 00 | ff ff f7 f7 f7 00 ff ff |........|........|
|00000470| f9 f9 f9 f7 f6 f6 f6 f6 | f6 f6 ff ff f7 f9 f9 f9 |........|........|
|00000480| ff ff 00 00 00 00 00 00 | 00 00 ff ff f7 f7 f7 00 |........|........|
|00000490| 00 f6 f6 f6 f6 f6 f6 f6 | f6 f7 f7 f9 f9 f9 ff ff |........|........|
|000004a0| 00 00 00 00 00 00 00 00 | 00 00 00 00 ff ff f7 f7 |........|........|
|000004b0| f7 00 00 f6 f6 f6 f6 f7 | f7 f9 f9 f9 ff ff 00 00 |........|........|
|000004c0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 ff ff |........|........|
|000004d0| f7 f7 f7 00 00 f7 f7 f9 | f9 f9 ff ff 00 00 00 00 |........|........|
|000004e0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000004f0| ff ff f7 f7 f7 f9 f9 f9 | ff ff 00 00 00 00 00 00 |........|........|
|00000500| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000510| 00 00 ff ff f7 f9 ff ff | 00 00 00 00 00 00 00 00 |........|........|
|00000520| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000530| 00 00 00 00 ff ff 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000540| 00 00 00 00 00 01 04 74 | 65 78 74 04 52 2a 63 68 |.......t|ext.R*ch|
|00000550| 04 54 45 58 54 00 00 01 | 41 04 56 69 65 77 0a 57 |.TEXT...|A.View.W|
|00000560| 69 6e 64 6f 77 4d 61 69 | 6e 04 9e 01 b5 02 12 04 |indowMai|n.......|
|00000570| 4e 61 6d 65 0a 57 69 6e | 64 6f 77 4d 61 69 6e 05 |Name.Win|dowMain.|
|00000580| 46 72 61 6d 65 01 30 0c | 48 61 73 42 61 63 6b 43 |Frame.0.|HasBackC|
|00000590| 6f 6c 6f 72 05 46 61 6c | 73 65 09 42 61 63 6b 43 |olor.Fal|se.BackC|
|000005a0| 6f 6c 6f 72 08 31 36 37 | 37 37 32 31 35 08 42 61 |olor.167|77215.Ba|
|000005b0| 63 6b 64 72 6f 70 01 30 | 05 54 69 74 6c 65 22 48 |ckdrop.0|.Title"H|
|000005c0| 65 78 61 64 65 63 69 6d | 61 6c 20 50 72 69 6d 65 |exadecim|al Prime|
|000005d0| 20 4e 75 6d 62 65 72 20 | 67 65 6e 65 72 61 74 6f | Number |generato|
|000005e0| 72 07 56 69 73 69 62 6c | 65 04 54 72 75 65 08 43 |r.Visibl|e.True.C|
|000005f0| 6c 6f 73 65 42 6f 78 04 | 54 72 75 65 08 47 72 6f |loseBox.|True.Gro|
|00000600| 77 49 63 6f 6e 05 46 61 | 6c 73 65 08 5a 6f 6f 6d |wIcon.Fa|lse.Zoom|
|00000610| 49 63 6f 6e 05 46 61 6c | 73 65 0b 42 61 6c 6c 6f |Icon.Fal|se.Ballo|
|00000620| 6f 6e 48 65 6c 70 00 09 | 50 6c 61 63 65 6d 65 6e |onHelp..|Placemen|
|00000630| 74 01 30 05 57 69 64 74 | 68 03 34 32 30 06 48 65 |t.0.Widt|h.420.He|
|00000640| 69 67 68 74 03 32 31 35 | 08 4d 69 6e 57 69 64 74 |ight.215|.MinWidt|
|00000650| 68 02 36 34 09 4d 69 6e | 48 65 69 67 68 74 02 36 |h.64.Min|Height.6|
|00000660| 34 08 4d 61 78 57 69 64 | 74 68 05 33 32 30 30 30 |4.MaxWid|th.32000|
|00000670| 09 4d 61 78 48 65 69 67 | 68 74 05 33 32 30 30 30 |.MaxHeig|ht.32000|
|00000680| 07 00 0a 57 69 6e 64 6f | 77 4d 61 69 6e 98 01 06 |...Windo|wMain...|
|00000690| 41 70 70 6c 65 74 00 00 | 00 00 02 0f 45 6e 61 62 |Applet..|....Enab|
|000006a0| 6c 65 4d 65 6e 75 49 74 | 65 6d 73 01 05 01 05 03 |leMenuIt|ems.....|
|000006b0| 15 53 75 62 20 45 6e 61 | 62 6c 65 4d 65 6e 75 49 |.Sub Ena|bleMenuI|
|000006c0| 74 65 6d 73 28 29 11 41 | 70 70 6c 65 41 62 6f 75 |tems().A|ppleAbou|
|000006d0| 74 2e 65 6e 61 62 6c 65 | 07 45 6e 64 20 53 75 62 |t.enable|.End Sub|
|000006e0| 04 4f 70 65 6e 01 00 01 | 00 03 0a 53 75 62 20 4f |.Open...|...Sub O|
|000006f0| 70 65 6e 28 29 00 07 45 | 6e 64 20 53 75 62 01 0a |pen()..E|nd Sub..|
|00000700| 41 70 70 6c 65 41 62 6f | 75 74 01 0a 01 0a 03 1a |AppleAbo|ut......|
|00000710| 46 75 6e 63 74 69 6f 6e | 20 41 63 74 69 6f 6e 20 |Function| Action |
|00000720| 41 73 20 42 6f 6f 6c 65 | 61 6e 0a 61 62 6f 75 74 |As Boole|an.about|
|00000730| 2e 73 68 6f 77 0c 45 6e | 64 20 46 75 6e 63 74 69 |.show.En|d Functi|
|00000740| 6f 6e 00 08 07 00 00 80 | 02 09 45 64 69 74 46 69 |on......|..EditFi|
|00000750| 65 6c 64 00 00 00 00 00 | 00 00 07 00 00 ac 01 0a |eld.....|........|
|00000760| 50 75 73 68 42 75 74 74 | 6f 6e 00 00 00 00 01 06 |PushButt|on......|
|00000770| 41 63 74 69 6f 6e 02 1a | 02 1a 0a 0c 53 75 62 20 |Action..|....Sub |
|00000780| 41 63 74 69 6f 6e 28 29 | 12 44 69 6d 20 77 20 61 |Action()|.Dim w a|
|00000790| 73 20 46 69 6e 64 50 72 | 69 6d 65 21 49 66 20 76 |s FindPr|ime!If v|
|000007a0| 61 6c 28 45 64 69 74 50 | 72 65 63 69 73 69 6f 6e |al(EditP|recision|
|000007b0| 2e 54 65 78 74 29 3c 37 | 20 74 68 65 6e 81 01 4d |.Text)<7| then..M|
|000007c0| 73 67 42 6f 78 20 22 50 | 72 69 6d 65 73 20 6f 66 |sgBox "P|rimes of|
|000007d0| 20 6c 65 73 73 20 74 68 | 61 6e 20 37 20 62 69 74 | less th|an 7 bit|
|000007e0| 73 20 69 6e 20 6c 65 6e | 67 74 68 20 61 72 65 20 |s in len|gth are |
|000007f0| 74 72 69 76 69 61 6c 20 | 74 6f 20 66 69 6e 64 22 |trivial |to find"|
|00000800| 06 72 65 74 75 72 6e 06 | 65 6e 64 20 69 66 0f 77 |.return.|end if.w|
|00000810| 3d 6e 65 77 20 46 69 6e | 64 50 72 69 6d 65 0b 77 |=new Fin|dPrime.w|
|00000820| 2e 42 6f 73 73 3d 73 65 | 6c 66 05 77 2e 72 75 6e |.Boss=se|lf.w.run|
|00000830| 07 45 6e 64 20 53 75 62 | 00 00 07 00 00 80 02 09 |.End Sub|........|
|00000840| 45 64 69 74 46 69 65 6c | 64 00 00 00 00 01 07 4b |EditFiel|d......K|
|00000850| 65 79 44 6f 77 6e 01 00 | 01 00 03 2a 46 75 6e 63 |eyDown..|...*Func|
|00000860| 74 69 6f 6e 20 4b 65 79 | 44 6f 77 6e 28 4b 65 79 |tion Key|Down(Key|
|00000870| 20 41 73 20 53 74 72 69 | 6e 67 29 20 41 73 20 42 | As Stri|ng) As B|
|00000880| 6f 6f 6c 65 61 6e 00 0c | 45 6e 64 20 46 75 6e 63 |oolean..|End Func|
|00000890| 74 69 6f 6e 00 00 07 00 | 00 b0 01 0a 53 74 61 74 |tion....|....Stat|
|000008a0| 69 63 54 65 78 74 00 00 | 00 00 01 09 4d 6f 75 73 |icText..|....Mous|
|000008b0| 65 4d 6f 76 65 01 00 01 | 00 03 29 53 75 62 20 4d |eMove...|..)Sub M|
|000008c0| 6f 75 73 65 4d 6f 76 65 | 28 58 20 41 73 20 49 6e |ouseMove|(X As In|
|000008d0| 74 65 67 65 72 2c 20 59 | 20 41 73 20 49 6e 74 65 |teger, Y| As Inte|
|000008e0| 67 65 72 29 00 07 45 6e | 64 20 53 75 62 00 00 07 |ger)..En|d Sub...|
|000008f0| 00 00 b0 01 0a 53 74 61 | 74 69 63 54 65 78 74 00 |.....Sta|ticText.|
|00000900| 00 00 00 00 00 00 07 00 | 00 b0 01 0a 53 74 61 74 |........|....Stat|
|00000910| 69 63 54 65 78 74 00 00 | 00 00 00 00 00 07 00 00 |icText..|........|
|00000920| 80 02 09 45 64 69 74 46 | 69 65 6c 64 00 00 00 00 |...EditF|ield....|
|00000930| 00 00 00 07 00 00 80 02 | 09 45 64 69 74 46 69 65 |........|.EditFie|
|00000940| 6c 64 00 00 00 00 00 00 | 00 08 09 45 64 69 74 46 |ld......|...EditF|
|00000950| 69 65 6c 64 20 04 4e 61 | 6d 65 09 45 64 69 74 50 |ield .Na|me.EditP|
|00000960| 72 69 6d 65 05 49 6e 64 | 65 78 0b 2d 32 31 34 37 |rime.Ind|ex.-2147|
|00000970| 34 38 33 36 34 38 0d 54 | 61 62 50 61 6e 65 6c 49 |483648.T|abPanelI|
|00000980| 6e 64 65 78 01 30 07 56 | 69 73 69 62 6c 65 04 54 |ndex.0.V|isible.T|
|00000990| 72 75 65 04 4c 65 66 74 | 02 32 32 03 54 6f 70 02 |rue.Left|.22.Top.|
|000009a0| 39 34 05 57 69 64 74 68 | 03 33 37 39 06 48 65 69 |94.Width|.379.Hei|
|000009b0| 67 68 74 02 39 38 0b 42 | 61 6c 6c 6f 6f 6e 48 65 |ght.98.B|alloonHe|
|000009c0| 6c 70 a8 01 54 68 65 20 | 70 72 69 6d 65 20 6e 75 |lp..The |prime nu|
|000009d0| 6d 62 65 72 73 20 61 72 | 65 20 64 69 73 70 6c 61 |mbers ar|e displa|
|000009e0| 79 65 64 20 69 6e 20 74 | 68 69 73 20 77 69 6e 64 |yed in t|his wind|
|000009f0| 6f 77 2e 20 20 47 65 6e | 65 72 61 74 69 6e 67 20 |ow. Gen|erating |
|00000a00| 61 20 6e 65 77 20 70 72 | 69 6d 65 20 64 6f 65 73 |a new pr|ime does|
|00000a10| 20 6e 6f 74 20 65 72 61 | 73 65 20 70 72 65 76 69 | not era|se previ|
|00000a20| 6f 75 73 20 72 65 73 75 | 6c 74 73 2e 13 44 69 73 |ous resu|lts..Dis|
|00000a30| 61 62 6c 65 64 42 61 6c | 6c 6f 6f 6e 48 65 6c 70 |abledBal|loonHelp|
|00000a40| 00 08 4c 6f 63 6b 4c 65 | 66 74 05 46 61 6c 73 65 |..LockLe|ft.False|
|00000a50| 07 4c 6f 63 6b 54 6f 70 | 05 46 61 6c 73 65 09 4c |.LockTop|.False.L|
|00000a60| 6f 63 6b 52 69 67 68 74 | 05 46 61 6c 73 65 0a 4c |ockRight|.False.L|
|00000a70| 6f 63 6b 42 6f 74 74 6f | 6d 05 46 61 6c 73 65 08 |ockBotto|m.False.|
|00000a80| 54 65 78 74 46 6f 6e 74 | 06 53 79 73 74 65 6d 08 |TextFont|.System.|
|00000a90| 54 65 78 74 53 69 7a 65 | 02 31 32 04 42 6f 6c 64 |TextSize|.12.Bold|
|00000aa0| 05 46 61 6c 73 65 06 49 | 74 61 6c 69 63 05 46 61 |.False.I|talic.Fa|
|00000ab0| 6c 73 65 09 55 6e 64 65 | 72 6c 69 6e 65 05 46 61 |lse.Unde|rline.Fa|
|00000ac0| 6c 73 65 06 42 6f 72 64 | 65 72 04 54 72 75 65 09 |lse.Bord|er.True.|
|00000ad0| 4d 75 6c 74 69 4c 69 6e | 65 04 54 72 75 65 09 53 |MultiLin|e.True.S|
|00000ae0| 63 72 6f 6c 6c 42 61 72 | 04 54 72 75 65 06 53 74 |crollBar|.True.St|
|00000af0| 79 6c 65 64 05 46 61 6c | 73 65 08 50 61 73 73 77 |yled.Fal|se.Passw|
|00000b00| 6f 72 64 05 46 61 6c 73 | 65 0c 55 73 65 46 6f 63 |ord.Fals|e.UseFoc|
|00000b10| 75 73 52 69 6e 67 04 54 | 72 75 65 08 52 65 61 64 |usRing.T|rue.Read|
|00000b20| 4f 6e 6c 79 05 46 61 6c | 73 65 09 4c 69 6d 69 74 |Only.Fal|se.Limit|
|00000b30| 54 65 78 74 01 30 0a 41 | 63 63 65 70 74 54 61 62 |Text.0.A|cceptTab|
|00000b40| 73 05 46 61 6c 73 65 09 | 54 65 78 74 43 6f 6c 6f |s.False.|TextColo|
|00000b50| 72 01 30 09 42 61 63 6b | 43 6f 6c 6f 72 08 31 36 |r.0.Back|Color.16|
|00000b60| 37 37 37 32 31 35 07 45 | 6e 61 62 6c 65 64 04 54 |777215.E|nabled.T|
|00000b70| 72 75 65 04 54 65 78 74 | 00 00 0a 50 75 73 68 42 |rue.Text|...PushB|
|00000b80| 75 74 74 6f 6e 17 04 4e | 61 6d 65 0b 50 75 73 68 |utton..N|ame.Push|
|00000b90| 42 75 74 74 6f 6e 31 05 | 49 6e 64 65 78 0b 2d 32 |Button1.|Index.-2|
|00000ba0| 31 34 37 34 38 33 36 34 | 38 0d 54 61 62 50 61 6e |14748364|8.TabPan|
|00000bb0| 65 6c 49 6e 64 65 78 01 | 30 07 56 69 73 69 62 6c |elIndex.|0.Visibl|
|00000bc0| 65 04 54 72 75 65 04 4c | 65 66 74 03 32 34 35 03 |e.True.L|eft.245.|
|00000bd0| 54 6f 70 02 32 30 05 57 | 69 64 74 68 03 31 35 36 |Top.20.W|idth.156|
|00000be0| 06 48 65 69 67 68 74 02 | 32 30 0b 42 61 6c 6c 6f |.Height.|20.Ballo|
|00000bf0| 6f 6e 48 65 6c 70 00 13 | 44 69 73 61 62 6c 65 64 |onHelp..|Disabled|
|00000c00| 42 61 6c 6c 6f 6f 6e 48 | 65 6c 70 00 08 4c 6f 63 |BalloonH|elp..Loc|
|00000c10| 6b 4c 65 66 74 05 46 61 | 6c 73 65 07 4c 6f 63 6b |kLeft.Fa|lse.Lock|
|00000c20| 54 6f 70 05 46 61 6c 73 | 65 09 4c 6f 63 6b 52 69 |Top.Fals|e.LockRi|
|00000c30| 67 68 74 05 46 61 6c 73 | 65 0a 4c 6f 63 6b 42 6f |ght.Fals|e.LockBo|
|00000c40| 74 74 6f 6d 05 46 61 6c | 73 65 08 54 65 78 74 46 |ttom.Fal|se.TextF|
|00000c50| 6f 6e 74 06 53 79 73 74 | 65 6d 08 54 65 78 74 53 |ont.Syst|em.TextS|
|00000c60| 69 7a 65 02 31 32 04 42 | 6f 6c 64 05 46 61 6c 73 |ize.12.B|old.Fals|
|00000c70| 65 06 49 74 61 6c 69 63 | 05 46 61 6c 73 65 09 55 |e.Italic|.False.U|
|00000c80| 6e 64 65 72 6c 69 6e 65 | 05 46 61 6c 73 65 07 43 |nderline|.False.C|
|00000c90| 61 70 74 69 6f 6e 0e 47 | 65 6e 65 72 61 74 65 20 |aption.G|enerate |
|00000ca0| 70 72 69 6d 65 07 44 65 | 66 61 75 6c 74 04 54 72 |prime.De|fault.Tr|
|00000cb0| 75 65 06 43 61 6e 63 65 | 6c 05 46 61 6c 73 65 07 |ue.Cance|l.False.|
|00000cc0| 45 6e 61 62 6c 65 64 04 | 54 72 75 65 01 09 45 64 |Enabled.|True..Ed|
|00000cd0| 69 74 46 69 65 6c 64 20 | 04 4e 61 6d 65 0d 45 64 |itField |.Name.Ed|
|00000ce0| 69 74 50 72 65 63 69 73 | 69 6f 6e 05 49 6e 64 65 |itPrecis|ion.Inde|
|00000cf0| 78 0b 2d 32 31 34 37 34 | 38 33 36 34 38 0d 54 61 |x.-21474|83648.Ta|
|00000d00| 62 50 61 6e 65 6c 49 6e | 64 65 78 01 30 07 56 69 |bPanelIn|dex.0.Vi|
|00000d10| 73 69 62 6c 65 04 54 72 | 75 65 04 4c 65 66 74 03 |sible.Tr|ue.Left.|
|00000d20| 31 33 30 03 54 6f 70 02 | 32 30 05 57 69 64 74 68 |130.Top.|20.Width|
|00000d30| 02 38 30 06 48 65 69 67 | 68 74 02 32 30 0b 42 61 |.80.Heig|ht.20.Ba|
|00000d40| 6c 6c 6f 6f 6e 48 65 6c | 70 1f 54 68 65 20 6c 65 |lloonHel|p.The le|
|00000d50| 6e 67 74 68 20 6f 66 20 | 74 68 65 20 70 72 69 6d |ngth of |the prim|
|00000d60| 65 20 6e 75 6d 62 65 72 | 2e 13 44 69 73 61 62 6c |e number|..Disabl|
|00000d70| 65 64 42 61 6c 6c 6f 6f | 6e 48 65 6c 70 00 08 4c |edBalloo|nHelp..L|
|00000d80| 6f 63 6b 4c 65 66 74 05 | 46 61 6c 73 65 07 4c 6f |ockLeft.|False.Lo|
|00000d90| 63 6b 54 6f 70 05 46 61 | 6c 73 65 09 4c 6f 63 6b |ckTop.Fa|lse.Lock|
|00000da0| 52 69 67 68 74 05 46 61 | 6c 73 65 0a 4c 6f 63 6b |Right.Fa|lse.Lock|
|00000db0| 42 6f 74 74 6f 6d 05 46 | 61 6c 73 65 08 54 65 78 |Bottom.F|alse.Tex|
|00000dc0| 74 46 6f 6e 74 06 53 79 | 73 74 65 6d 08 54 65 78 |tFont.Sy|stem.Tex|
|00000dd0| 74 53 69 7a 65 02 31 32 | 04 42 6f 6c 64 05 46 61 |tSize.12|.Bold.Fa|
|00000de0| 6c 73 65 06 49 74 61 6c | 69 63 05 46 61 6c 73 65 |lse.Ital|ic.False|
|00000df0| 09 55 6e 64 65 72 6c 69 | 6e 65 05 46 61 6c 73 65 |.Underli|ne.False|
|00000e00| 06 42 6f 72 64 65 72 04 | 54 72 75 65 09 4d 75 6c |.Border.|True.Mul|
|00000e10| 74 69 4c 69 6e 65 05 46 | 61 6c 73 65 09 53 63 72 |tiLine.F|alse.Scr|
|00000e20| 6f 6c 6c 42 61 72 04 54 | 72 75 65 06 53 74 79 6c |ollBar.T|rue.Styl|
|00000e30| 65 64 05 46 61 6c 73 65 | 08 50 61 73 73 77 6f 72 |ed.False|.Passwor|
|00000e40| 64 05 46 61 6c 73 65 0c | 55 73 65 46 6f 63 75 73 |d.False.|UseFocus|
|00000e50| 52 69 6e 67 04 54 72 75 | 65 08 52 65 61 64 4f 6e |Ring.Tru|e.ReadOn|
|00000e60| 6c 79 05 46 61 6c 73 65 | 09 4c 69 6d 69 74 54 65 |ly.False|.LimitTe|
|00000e70| 78 74 01 30 0a 41 63 63 | 65 70 74 54 61 62 73 05 |xt.0.Acc|eptTabs.|
|00000e80| 46 61 6c 73 65 09 54 65 | 78 74 43 6f 6c 6f 72 01 |False.Te|xtColor.|
|00000e90| 30 09 42 61 63 6b 43 6f | 6c 6f 72 08 31 36 37 37 |0.BackCo|lor.1677|
|00000ea0| 37 32 31 35 07 45 6e 61 | 62 6c 65 64 04 54 72 75 |7215.Ena|bled.Tru|
|00000eb0| 65 04 54 65 78 74 00 02 | 0a 53 74 61 74 69 63 54 |e.Text..|.StaticT|
|00000ec0| 65 78 74 17 04 4e 61 6d | 65 0b 53 74 61 74 69 63 |ext..Nam|e.Static|
|00000ed0| 54 65 78 74 31 05 49 6e | 64 65 78 0b 2d 32 31 34 |Text1.In|dex.-214|
|00000ee0| 37 34 38 33 36 34 38 0d | 54 61 62 50 61 6e 65 6c |7483648.|TabPanel|
|00000ef0| 49 6e 64 65 78 01 30 07 | 56 69 73 69 62 6c 65 04 |Index.0.|Visible.|
|00000f00| 54 72 75 65 04 4c 65 66 | 74 02 32 32 03 54 6f 70 |True.Lef|t.22.Top|
|00000f10| 02 32 33 05 57 69 64 74 | 68 03 31 30 32 06 48 65 |.23.Widt|h.102.He|
|00000f20| 69 67 68 74 02 31 37 0b | 42 61 6c 6c 6f 6f 6e 48 |ight.17.|BalloonH|
|00000f30| 65 6c 70 00 13 44 69 73 | 61 62 6c 65 64 42 61 6c |elp..Dis|abledBal|
|00000f40| 6c 6f 6f 6e 48 65 6c 70 | 00 08 4c 6f 63 6b 4c 65 |loonHelp|..LockLe|
|00000f50| 66 74 05 46 61 6c 73 65 | 07 4c 6f 63 6b 54 6f 70 |ft.False|.LockTop|
|00000f60| 05 46 61 6c 73 65 09 4c | 6f 63 6b 52 69 67 68 74 |.False.L|ockRight|
|00000f70| 05 46 61 6c 73 65 0a 4c | 6f 63 6b 42 6f 74 74 6f |.False.L|ockBotto|
|00000f80| 6d 05 46 61 6c 73 65 08 | 54 65 78 74 46 6f 6e 74 |m.False.|TextFont|
|00000f90| 06 53 79 73 74 65 6d 08 | 54 65 78 74 53 69 7a 65 |.System.|TextSize|
|00000fa0| 02 31 32 04 42 6f 6c 64 | 05 46 61 6c 73 65 06 49 |.12.Bold|.False.I|
|00000fb0| 74 61 6c 69 63 05 46 61 | 6c 73 65 09 55 6e 64 65 |talic.Fa|lse.Unde|
|00000fc0| 72 6c 69 6e 65 05 46 61 | 6c 73 65 04 54 65 78 74 |rline.Fa|lse.Text|
|00000fd0| 0f 4e 75 6d 62 65 72 20 | 6f 66 20 62 69 74 73 3a |.Number |of bits:|
|00000fe0| 09 54 65 78 74 41 6c 69 | 67 6e 01 30 09 54 65 78 |.TextAli|gn.0.Tex|
|00000ff0| 74 43 6f 6c 6f 72 01 30 | 09 4d 75 6c 74 69 4c 69 |tColor.0|.MultiLi|
|00001000| 6e 65 05 46 61 6c 73 65 | 03 0a 53 74 61 74 69 63 |ne.False|..Static|
|00001010| 54 65 78 74 17 04 4e 61 | 6d 65 0b 53 74 61 74 69 |Text..Na|me.Stati|
|00001020| 63 54 65 78 74 33 05 49 | 6e 64 65 78 0b 2d 32 31 |cText3.I|ndex.-21|
|00001030| 34 37 34 38 33 36 34 38 | 0d 54 61 62 50 61 6e 65 |47483648|.TabPane|
|00001040| 6c 49 6e 64 65 78 01 30 | 07 56 69 73 69 62 6c 65 |lIndex.0|.Visible|
|00001050| 04 54 72 75 65 04 4c 65 | 66 74 02 32 32 03 54 6f |.True.Le|ft.22.To|
|00001060| 70 02 36 32 05 57 69 64 | 74 68 02 34 35 06 48 65 |p.62.Wid|th.45.He|
|00001070| 69 67 68 74 02 31 36 0b | 42 61 6c 6c 6f 6f 6e 48 |ight.16.|BalloonH|
|00001080| 65 6c 70 00 13 44 69 73 | 61 62 6c 65 64 42 61 6c |elp..Dis|abledBal|
|00001090| 6c 6f 6f 6e 48 65 6c 70 | 00 08 4c 6f 63 6b 4c 65 |loonHelp|..LockLe|
|000010a0| 66 74 05 46 61 6c 73 65 | 07 4c 6f 63 6b 54 6f 70 |ft.False|.LockTop|
|000010b0| 05 46 61 6c 73 65 09 4c | 6f 63 6b 52 69 67 68 74 |.False.L|ockRight|
|000010c0| 05 46 61 6c 73 65 0a 4c | 6f 63 6b 42 6f 74 74 6f |.False.L|ockBotto|
|000010d0| 6d 05 46 61 6c 73 65 08 | 54 65 78 74 46 6f 6e 74 |m.False.|TextFont|
|000010e0| 06 53 79 73 74 65 6d 08 | 54 65 78 74 53 69 7a 65 |.System.|TextSize|
|000010f0| 02 31 32 04 42 6f 6c 64 | 05 46 61 6c 73 65 06 49 |.12.Bold|.False.I|
|00001100| 74 61 6c 69 63 05 46 61 | 6c 73 65 09 55 6e 64 65 |talic.Fa|lse.Unde|
|00001110| 72 6c 69 6e 65 05 46 61 | 6c 73 65 04 54 65 78 74 |rline.Fa|lse.Text|
|00001120| 06 54 72 69 61 6c 23 09 | 54 65 78 74 41 6c 69 67 |.Trial#.|TextAlig|
|00001130| 6e 01 30 09 54 65 78 74 | 43 6f 6c 6f 72 01 30 09 |n.0.Text|Color.0.|
|00001140| 4d 75 6c 74 69 4c 69 6e | 65 05 46 61 6c 73 65 04 |MultiLin|e.False.|
|00001150| 0a 53 74 61 74 69 63 54 | 65 78 74 17 04 4e 61 6d |.StaticT|ext..Nam|
|00001160| 65 0b 53 74 61 74 69 63 | 54 65 78 74 34 05 49 6e |e.Static|Text4.In|
|00001170| 64 65 78 0b 2d 32 31 34 | 37 34 38 33 36 34 38 0d |dex.-214|7483648.|
|00001180| 54 61 62 50 61 6e 65 6c | 49 6e 64 65 78 01 30 07 |TabPanel|Index.0.|
|00001190| 56 69 73 69 62 6c 65 04 | 54 72 75 65 04 4c 65 66 |Visible.|True.Lef|
|000011a0| 74 03 31 35 36 03 54 6f | 70 02 36 32 05 57 69 64 |t.156.To|p.62.Wid|
|000011b0| 74 68 02 37 31 06 48 65 | 69 67 68 74 02 31 36 0b |th.71.He|ight.16.|
|000011c0| 42 61 6c 6c 6f 6f 6e 48 | 65 6c 70 00 13 44 69 73 |BalloonH|elp..Dis|
|000011d0| 61 62 6c 65 64 42 61 6c | 6c 6f 6f 6e 48 65 6c 70 |abledBal|loonHelp|
|000011e0| 00 08 4c 6f 63 6b 4c 65 | 66 74 05 46 61 6c 73 65 |..LockLe|ft.False|
|000011f0| 07 4c 6f 63 6b 54 6f 70 | 05 46 61 6c 73 65 09 4c |.LockTop|.False.L|
|00001200| 6f 63 6b 52 69 67 68 74 | 05 46 61 6c 73 65 0a 4c |ockRight|.False.L|
|00001210| 6f 63 6b 42 6f 74 74 6f | 6d 05 46 61 6c 73 65 08 |ockBotto|m.False.|
|00001220| 54 65 78 74 46 6f 6e 74 | 06 53 79 73 74 65 6d 08 |TextFont|.System.|
|00001230| 54 65 78 74 53 69 7a 65 | 02 31 32 04 42 6f 6c 64 |TextSize|.12.Bold|
|00001240| 05 46 61 6c 73 65 06 49 | 74 61 6c 69 63 05 46 61 |.False.I|talic.Fa|
|00001250| 6c 73 65 09 55 6e 64 65 | 72 6c 69 6e 65 05 46 61 |lse.Unde|rline.Fa|
|00001260| 6c 73 65 04 54 65 78 74 | 0a 4e 6f 77 20 64 6f 69 |lse.Text|.Now doi|
|00001270| 6e 67 3a 09 54 65 78 74 | 41 6c 69 67 6e 01 30 09 |ng:.Text|Align.0.|
|00001280| 54 65 78 74 43 6f 6c 6f | 72 01 30 09 4d 75 6c 74 |TextColo|r.0.Mult|
|00001290| 69 4c 69 6e 65 05 46 61 | 6c 73 65 05 09 45 64 69 |iLine.Fa|lse..Edi|
|000012a0| 74 46 69 65 6c 64 20 04 | 4e 61 6d 65 0c 53 74 61 |tField .|Name.Sta|
|000012b0| 74 69 63 41 63 74 69 6f | 6e 05 49 6e 64 65 78 0b |ticActio|n.Index.|
|000012c0| 2d 32 31 34 37 34 38 33 | 36 34 38 0d 54 61 62 50 |-2147483|648.TabP|
|000012d0| 61 6e 65 6c 49 6e 64 65 | 78 01 30 07 56 69 73 69 |anelInde|x.0.Visi|
|000012e0| 62 6c 65 04 54 72 75 65 | 04 4c 65 66 74 03 32 34 |ble.True|.Left.24|
|000012f0| 35 03 54 6f 70 02 35 39 | 05 57 69 64 74 68 03 31 |5.Top.59|.Width.1|
|00001300| 35 36 06 48 65 69 67 68 | 74 02 32 30 0b 42 61 6c |56.Heigh|t.20.Bal|
|00001310| 6c 6f 6f 6e 48 65 6c 70 | 8e 01 41 20 6e 75 6d 62 |loonHelp|..A numb|
|00001320| 65 72 20 69 73 20 64 65 | 63 6c 61 72 65 64 20 70 |er is de|clared p|
|00001330| 72 69 6d 65 20 69 66 20 | 69 74 20 70 61 73 73 65 |rime if |it passe|
|00001340| 73 20 35 20 69 74 65 72 | 61 74 69 6f 6e 73 20 6f |s 5 iter|ations o|
|00001350| 66 20 74 68 65 20 4d 69 | 6c 6c 65 72 2d 52 61 62 |f the Mi|ller-Rab|
|00001360| 69 6e 20 74 65 73 74 2e | 13 44 69 73 61 62 6c 65 |in test.|.Disable|
|00001370| 64 42 61 6c 6c 6f 6f 6e | 48 65 6c 70 00 08 4c 6f |dBalloon|Help..Lo|
|00001380| 63 6b 4c 65 66 74 05 46 | 61 6c 73 65 07 4c 6f 63 |ckLeft.F|alse.Loc|
|00001390| 6b 54 6f 70 05 46 61 6c | 73 65 09 4c 6f 63 6b 52 |kTop.Fal|se.LockR|
|000013a0| 69 67 68 74 05 46 61 6c | 73 65 0a 4c 6f 63 6b 42 |ight.Fal|se.LockB|
|000013b0| 6f 74 74 6f 6d 05 46 61 | 6c 73 65 08 54 65 78 74 |ottom.Fa|lse.Text|
|000013c0| 46 6f 6e 74 06 53 79 73 | 74 65 6d 08 54 65 78 74 |Font.Sys|tem.Text|
|000013d0| 53 69 7a 65 02 31 32 04 | 42 6f 6c 64 05 46 61 6c |Size.12.|Bold.Fal|
|000013e0| 73 65 06 49 74 61 6c 69 | 63 05 46 61 6c 73 65 09 |se.Itali|c.False.|
|000013f0| 55 6e 64 65 72 6c 69 6e | 65 05 46 61 6c 73 65 06 |Underlin|e.False.|
|00001400| 42 6f 72 64 65 72 04 54 | 72 75 65 09 4d 75 6c 74 |Border.T|rue.Mult|
|00001410| 69 4c 69 6e 65 05 46 61 | 6c 73 65 09 53 63 72 6f |iLine.Fa|lse.Scro|
|00001420| 6c 6c 42 61 72 04 54 72 | 75 65 06 53 74 79 6c 65 |llBar.Tr|ue.Style|
|00001430| 64 05 46 61 6c 73 65 08 | 50 61 73 73 77 6f 72 64 |d.False.|Password|
|00001440| 05 46 61 6c 73 65 0c 55 | 73 65 46 6f 63 75 73 52 |.False.U|seFocusR|
|00001450| 69 6e 67 04 54 72 75 65 | 08 52 65 61 64 4f 6e 6c |ing.True|.ReadOnl|
|00001460| 79 04 54 72 75 65 09 4c | 69 6d 69 74 54 65 78 74 |y.True.L|imitText|
|00001470| 01 30 0a 41 63 63 65 70 | 74 54 61 62 73 05 46 61 |.0.Accep|tTabs.Fa|
|00001480| 6c 73 65 09 54 65 78 74 | 43 6f 6c 6f 72 01 30 09 |lse.Text|Color.0.|
|00001490| 42 61 63 6b 43 6f 6c 6f | 72 08 31 36 37 37 37 32 |BackColo|r.167772|
|000014a0| 31 35 07 45 6e 61 62 6c | 65 64 04 54 72 75 65 04 |15.Enabl|ed.True.|
|000014b0| 54 65 78 74 00 06 09 45 | 64 69 74 46 69 65 6c 64 |Text...E|ditField|
|000014c0| 20 04 4e 61 6d 65 0b 54 | 72 69 61 6c 4e 75 6d 62 | .Name.T|rialNumb|
|000014d0| 65 72 05 49 6e 64 65 78 | 0b 2d 32 31 34 37 34 38 |er.Index|.-214748|
|000014e0| 33 36 34 38 0d 54 61 62 | 50 61 6e 65 6c 49 6e 64 |3648.Tab|PanelInd|
|000014f0| 65 78 01 30 07 56 69 73 | 69 62 6c 65 04 54 72 75 |ex.0.Vis|ible.Tru|
|00001500| 65 04 4c 65 66 74 02 36 | 36 03 54 6f 70 02 35 39 |e.Left.6|6.Top.59|
|00001510| 05 57 69 64 74 68 02 33 | 35 06 48 65 69 67 68 74 |.Width.3|5.Height|
|00001520| 02 31 39 0b 42 61 6c 6c | 6f 6f 6e 48 65 6c 70 87 |.19.Ball|oonHelp.|
|00001530| 02 54 68 65 20 61 6c 67 | 6f 72 69 74 68 6d 20 74 |.The alg|orithm t|
|00001540| 65 73 74 73 20 72 61 6e | 64 6f 6d 20 6e 75 6d 62 |ests ran|dom numb|
|00001550| 65 72 73 20 66 6f 72 20 | 70 72 69 6d 61 6c 69 74 |ers for |primalit|
|00001560| 79 2e 20 20 54 68 69 73 | 20 69 73 20 74 68 65 20 |y. This| is the |
|00001570| 6e 75 6d 62 65 72 20 6f | 66 20 74 69 6d 65 73 20 |number o|f times |
|00001580| 69 74 20 68 61 73 20 74 | 72 69 65 64 20 61 20 72 |it has t|ried a r|
|00001590| 61 6e 64 6f 6d 20 6e 75 | 6d 62 65 72 2c 20 69 6e |andom nu|mber, in|
|000015a0| 63 6c 75 64 69 6e 67 20 | 74 68 65 20 70 72 65 73 |cluding |the pres|
|000015b0| 65 6e 74 20 6f 6e 65 2e | 13 44 69 73 61 62 6c 65 |ent one.|.Disable|
|000015c0| 64 42 61 6c 6c 6f 6f 6e | 48 65 6c 70 00 08 4c 6f |dBalloon|Help..Lo|
|000015d0| 63 6b 4c 65 66 74 05 46 | 61 6c 73 65 07 4c 6f 63 |ckLeft.F|alse.Loc|
|000015e0| 6b 54 6f 70 05 46 61 6c | 73 65 09 4c 6f 63 6b 52 |kTop.Fal|se.LockR|
|000015f0| 69 67 68 74 05 46 61 6c | 73 65 0a 4c 6f 63 6b 42 |ight.Fal|se.LockB|
|00001600| 6f 74 74 6f 6d 05 46 61 | 6c 73 65 08 54 65 78 74 |ottom.Fa|lse.Text|
|00001610| 46 6f 6e 74 06 53 79 73 | 74 65 6d 08 54 65 78 74 |Font.Sys|tem.Text|
|00001620| 53 69 7a 65 02 31 32 04 | 42 6f 6c 64 05 46 61 6c |Size.12.|Bold.Fal|
|00001630| 73 65 06 49 74 61 6c 69 | 63 05 46 61 6c 73 65 09 |se.Itali|c.False.|
|00001640| 55 6e 64 65 72 6c 69 6e | 65 05 46 61 6c 73 65 06 |Underlin|e.False.|
|00001650| 42 6f 72 64 65 72 04 54 | 72 75 65 09 4d 75 6c 74 |Border.T|rue.Mult|
|00001660| 69 4c 69 6e 65 05 46 61 | 6c 73 65 09 53 63 72 6f |iLine.Fa|lse.Scro|
|00001670| 6c 6c 42 61 72 04 54 72 | 75 65 06 53 74 79 6c 65 |llBar.Tr|ue.Style|
|00001680| 64 05 46 61 6c 73 65 08 | 50 61 73 73 77 6f 72 64 |d.False.|Password|
|00001690| 05 46 61 6c 73 65 0c 55 | 73 65 46 6f 63 75 73 52 |.False.U|seFocusR|
|000016a0| 69 6e 67 04 54 72 75 65 | 08 52 65 61 64 4f 6e 6c |ing.True|.ReadOnl|
|000016b0| 79 04 54 72 75 65 09 4c | 69 6d 69 74 54 65 78 74 |y.True.L|imitText|
|000016c0| 01 30 0a 41 63 63 65 70 | 74 54 61 62 73 05 46 61 |.0.Accep|tTabs.Fa|
|000016d0| 6c 73 65 09 54 65 78 74 | 43 6f 6c 6f 72 01 30 09 |lse.Text|Color.0.|
|000016e0| 42 61 63 6b 43 6f 6c 6f | 72 08 31 36 37 37 37 32 |BackColo|r.167772|
|000016f0| 31 35 07 45 6e 61 62 6c | 65 64 04 54 72 75 65 04 |15.Enabl|ed.True.|
|00001700| 54 65 78 74 00 07 00 02 | 41 04 4d 65 6e 75 04 4d |Text....|A.Menu.M|
|00001710| 65 6e 75 05 a4 01 a4 01 | 90 06 ac 04 04 01 00 05 |enu.....|........|
|00001720| 41 70 70 6c 65 80 80 80 | 80 10 00 00 00 00 00 07 |Apple...|........|
|00001730| 00 00 3c 08 4d 65 6e 75 | 49 74 65 6d 00 00 00 00 |..<.Menu|Item....|
|00001740| 00 00 00 02 00 08 41 62 | 6f 75 74 2e 2e 2e 0a 41 |......Ab|out....A|
|00001750| 70 70 6c 65 41 62 6f 75 | 74 80 80 80 80 10 00 00 |ppleAbou|t.......|
|00001760| 00 00 00 07 00 00 3c 08 | 4d 65 6e 75 49 74 65 6d |......<.|MenuItem|
|00001770| 00 00 00 00 00 00 00 00 | 02 00 00 80 80 80 80 10 |........|........|
|00001780| 00 00 00 00 00 07 00 00 | 3c 08 4d 65 6e 75 49 74 |........|<.MenuIt|
|00001790| 65 6d 00 00 00 00 00 00 | 00 00 00 04 46 69 6c 65 |em......|....File|
|000017a0| 00 80 80 80 80 10 00 00 | 00 00 00 07 00 00 3c 08 |........|......<.|
|000017b0| 4d 65 6e 75 49 74 65 6d | 00 00 00 00 00 00 00 02 |MenuItem|........|
|000017c0| 00 04 51 75 69 74 08 46 | 69 6c 65 51 75 69 74 80 |..Quit.F|ileQuit.|
|000017d0| 80 80 80 10 01 51 00 00 | 00 00 07 00 00 3c 0c 51 |.....Q..|.....<.Q|
|000017e0| 75 69 74 4d 65 6e 75 49 | 74 65 6d 00 00 00 00 00 |uitMenuI|tem.....|
|000017f0| 00 00 00 02 00 00 80 80 | 80 80 10 00 00 00 00 00 |........|........|
|00001800| 07 00 00 3c 08 4d 65 6e | 75 49 74 65 6d 00 00 00 |...<.Men|uItem...|
|00001810| 00 00 00 00 00 00 04 45 | 64 69 74 00 80 80 80 80 |.......E|dit.....|
|00001820| 10 00 00 00 00 00 07 00 | 00 3c 08 4d 65 6e 75 49 |........|.<.MenuI|
|00001830| 74 65 6d 00 00 00 00 00 | 00 00 05 00 03 43 75 74 |tem.....|.....Cut|
|00001840| 07 45 64 69 74 43 75 74 | 80 80 80 80 10 01 58 00 |.EditCut|......X.|
|00001850| 00 00 00 07 00 00 3c 08 | 4d 65 6e 75 49 74 65 6d |......<.|MenuItem|
|00001860| 00 00 00 00 00 00 00 00 | 00 04 43 6f 70 79 08 45 |........|..Copy.E|
|00001870| 64 69 74 43 6f 70 79 80 | 80 80 80 10 01 43 00 00 |ditCopy.|.....C..|
|00001880| 00 00 07 00 00 3c 08 4d | 65 6e 75 49 74 65 6d 00 |.....<.M|enuItem.|
|00001890| 00 00 00 00 00 00 00 00 | 05 50 61 73 74 65 09 45 |........|.Paste.E|
|000018a0| 64 69 74 50 61 73 74 65 | 80 80 80 80 10 01 56 00 |ditPaste|......V.|
|000018b0| 00 00 00 07 00 00 3c 08 | 4d 65 6e 75 49 74 65 6d |......<.|MenuItem|
|000018c0| 00 00 00 00 00 00 00 00 | 00 05 43 6c 65 61 72 09 |........|..Clear.|
|000018d0| 45 64 69 74 43 6c 65 61 | 72 80 80 80 80 10 00 00 |EditClea|r.......|
|000018e0| 00 00 00 07 00 00 3c 08 | 4d 65 6e 75 49 74 65 6d |......<.|MenuItem|
|000018f0| 00 00 00 00 00 00 00 00 | 02 00 00 80 80 80 80 10 |........|........|
|00001900| 00 00 00 00 00 07 00 00 | 3c 08 4d 65 6e 75 49 74 |........|<.MenuIt|
|00001910| 65 6d 00 00 00 00 00 00 | 00 00 02 00 00 80 80 80 |em......|........|
|00001920| 80 10 00 00 00 00 00 07 | 00 00 3c 08 4d 65 6e 75 |........|..<.Menu|
|00001930| 49 74 65 6d 00 00 00 00 | 00 00 00 00 05 41 05 43 |Item....|.....A.C|
|00001940| 6c 61 73 73 09 46 69 6e | 64 50 72 69 6d 65 93 01 |lass.Fin|dPrime..|
|00001950| 9b 03 8e 0e aa 0a 07 00 | 09 46 69 6e 64 50 72 69 |........|.FindPri|
|00001960| 6d 65 20 06 54 68 72 65 | 61 64 00 03 0d 70 20 61 |me .Thre|ad...p a|
|00001970| 73 20 4c 69 6e 74 65 67 | 65 72 00 14 70 72 65 63 |s Linteg|er..prec|
|00001980| 69 73 69 6f 6e 20 61 73 | 20 69 6e 74 65 67 65 72 |ision as| integer|
|00001990| 00 12 42 6f 73 73 20 61 | 73 20 57 69 6e 64 6f 77 |..Boss a|s Window|
|000019a0| 4d 61 69 6e 00 02 05 52 | 61 62 69 6e 00 07 42 6f |Main...R|abin..Bo|
|000019b0| 6f 6c 65 61 6e 00 02 04 | 02 11 aa 01 1b 46 75 6e |olean...|.....Fun|
|000019c0| 63 74 69 6f 6e 20 52 61 | 62 69 6e 28 29 20 41 73 |ction Ra|bin() As|
|000019d0| 20 42 6f 6f 6c 65 61 6e | 22 52 45 4d 20 72 65 74 | Boolean|"REM ret|
|000019e0| 75 72 6e 20 74 72 75 65 | 20 69 66 20 6e 75 6d 62 |urn true| if numb|
|000019f0| 65 72 20 69 73 20 70 72 | 69 6d 65 29 52 45 4d 20 |er is pr|ime)REM |
|00001a00| 75 73 69 6e 67 20 4d 69 | 6c 6c 65 72 2d 52 61 62 |using Mi|ller-Rab|
|00001a10| 69 6e 20 70 72 69 6d 61 | 6c 69 74 79 20 74 65 73 |in prima|lity tes|
|00001a20| 74 69 6e 67 2e 3f 52 45 | 4d 20 28 61 6e 79 20 67 |ting.?RE|M (any g|
|00001a30| 6f 6f 64 20 62 6f 6f 6b | 20 6f 6e 20 63 72 79 70 |ood book| on cryp|
|00001a40| 74 6f 67 72 61 70 68 79 | 20 73 68 6f 75 6c 64 20 |tography| should |
|00001a50| 64 65 73 63 72 69 62 65 | 20 74 68 69 73 20 6d 65 |describe| this me|
|00001a60| 74 68 6f 64 29 13 64 69 | 6d 20 6d 61 78 65 20 61 |thod).di|m maxe a|
|00001a70| 73 20 69 6e 74 65 67 65 | 72 1a 64 69 6d 20 6d 79 |s intege|r.dim my|
|00001a80| 70 72 65 63 69 73 69 6f | 6e 20 61 73 20 69 6e 74 |precisio|n as int|
|00001a90| 65 67 65 72 14 64 69 6d | 20 70 72 69 6d 65 20 61 |eger.dim| prime a|
|00001aa0| 73 20 62 6f 6f 6c 65 61 | 6e 10 64 69 6d 20 69 20 |s boolea|n.dim i |
|00001ab0| 61 73 20 69 6e 74 65 67 | 65 72 22 64 69 6d 20 62 |as integ|er"dim b|
|00001ac0| 2c 20 63 6f 75 6e 74 2c | 20 62 69 74 2c 20 6a 2c |, count,| bit, j,|
|00001ad0| 20 6b 20 61 73 20 69 6e | 74 65 67 65 72 11 64 69 | k as in|teger.di|
|00001ae0| 6d 20 6d 20 61 73 20 4c | 69 6e 74 65 67 65 72 11 |m m as L|integer.|
|00001af0| 64 69 6d 20 61 20 61 73 | 20 4c 69 6e 74 65 67 65 |dim a as| Lintege|
|00001b00| 72 11 64 69 6d 20 7a 20 | 61 73 20 4c 69 6e 74 65 |r.dim z |as Linte|
|00001b10| 67 65 72 11 64 69 6d 20 | 63 20 61 73 20 4c 69 6e |ger.dim |c as Lin|
|00001b20| 74 65 67 65 72 0f 63 3d | 20 6e 65 77 20 4c 69 6e |teger.c=| new Lin|
|00001b30| 74 65 67 65 72 0e 6d 3d | 6e 65 77 20 4c 69 6e 74 |teger.m=|new Lint|
|00001b40| 65 67 65 72 0e 61 3d 6e | 65 77 20 4c 69 6e 74 65 |eger.a=n|ew Linte|
|00001b50| 67 65 72 0e 7a 3d 6e 65 | 77 20 4c 69 6e 74 65 67 |ger.z=ne|w Linteg|
|00001b60| 65 72 17 6d 79 70 72 65 | 63 69 73 69 6f 6e 3d 70 |er.mypre|cision=p|
|00001b70| 72 65 63 69 73 69 6f 6e | 2a 32 19 69 66 20 6d 79 |recision|*2.if my|
|00001b80| 70 72 65 63 69 73 69 6f | 6e 3e 31 30 32 34 20 74 |precisio|n>1024 t|
|00001b90| 68 65 6e 20 10 6d 79 70 | 72 65 63 69 73 69 6f 6e |hen .myp|recision|
|00001ba0| 3d 31 30 32 34 06 65 6e | 64 20 69 66 17 61 2e 70 |=1024.en|d if.a.p|
|00001bb0| 72 65 63 69 73 69 6f 6e | 3d 6d 79 70 72 65 63 69 |recision|=mypreci|
|00001bc0| 73 69 6f 6e 17 7a 2e 70 | 72 65 63 69 73 69 6f 6e |sion.z.p|recision|
|00001bd0| 3d 6d 79 70 72 65 63 69 | 73 69 6f 6e 17 63 2e 70 |=mypreci|sion.c.p|
|00001be0| 72 65 63 69 73 69 6f 6e | 3d 6d 79 70 72 65 63 69 |recision|=mypreci|
|00001bf0| 73 69 6f 6e 17 6d 2e 70 | 72 65 63 69 73 69 6f 6e |sion.m.p|recision|
|00001c00| 3d 6d 79 70 72 65 63 69 | 73 69 6f 6e 0b 70 72 69 |=mypreci|sion.pri|
|00001c10| 6d 65 3d 66 61 6c 73 65 | 24 72 65 6d 20 73 65 74 |me=false|$rem set|
|00001c20| 74 69 6e 67 20 75 70 20 | 66 6f 72 20 74 65 73 74 |ting up |for test|
|00001c30| 20 4d 69 6c 6c 65 72 2d | 52 61 62 69 6e 28 52 45 | Miller-|Rabin(RE|
|00001c40| 4d 20 53 74 65 70 20 6e | 75 6d 62 65 72 73 20 61 |M Step n|umbers a|
|00001c50| 73 20 64 65 73 63 72 69 | 62 65 64 20 69 6e 20 53 |s descri|bed in S|
|00001c60| 74 69 6e 73 6f 6e 25 52 | 45 4d 20 31 2e 20 57 72 |tinson%R|EM 1. Wr|
|00001c70| 69 74 65 20 6e 2d 31 3d | 6d 2a 32 5e 6b 20 77 68 |ite n-1=|m*2^k wh|
|00001c80| 65 72 65 20 6d 20 69 73 | 20 6f 64 64 2d 52 45 4d |ere m is| odd-REM|
|00001c90| 20 6b 20 3d 20 62 61 73 | 65 20 32 20 65 78 70 6f | k = bas|e 2 expo|
|00001ca0| 6e 65 6e 74 3d 23 20 7a | 65 72 6f 73 20 61 74 20 |nent=# z|eros at |
|00001cb0| 65 6e 64 20 6f 66 20 70 | 2d 31 2b 42 6f 73 73 2e |end of p|-1+Boss.|
|00001cc0| 53 74 61 74 69 63 41 63 | 74 69 6f 6e 2e 54 65 78 |StaticAc|tion.Tex|
|00001cd0| 74 3d 22 44 6f 69 6e 67 | 20 52 61 62 69 6e 2d 4d |t="Doing| Rabin-M|
|00001ce0| 69 6c 6c 65 72 22 09 6d | 2e 65 71 75 61 6c 20 70 |iller".m|.equal p|
|00001cf0| 0b 6d 2e 44 65 63 72 65 | 6d 65 6e 74 11 72 65 6d |.m.Decre|ment.rem|
|00001d00| 20 20 6d 20 69 73 20 6e | 6f 77 20 70 2d 31 29 52 | m is n|ow p-1)R|
|00001d10| 45 4d 20 66 69 6e 64 20 | 74 68 65 20 6e 75 6d 62 |EM find |the numb|
|00001d20| 65 72 20 6f 66 20 73 69 | 67 6e 69 66 69 63 61 6e |er of si|gnifican|
|00001d30| 74 20 64 69 67 69 74 73 | 0e 6d 61 78 65 3d 70 72 |t digits|.maxe=pr|
|00001d40| 65 63 69 73 69 6f 6e 21 | 77 68 69 6c 65 20 6d 2e |ecision!|while m.|
|00001d50| 69 61 72 72 61 79 28 6d | 61 78 65 29 3d 30 20 61 |iarray(m|axe)=0 a|
|00001d60| 6e 64 20 6d 61 78 65 3e | 30 0b 6d 61 78 65 3d 6d |nd maxe>|0.maxe=m|
|00001d70| 61 78 65 2d 31 04 77 65 | 6e 64 07 63 6f 75 6e 74 |axe-1.we|nd.count|
|00001d80| 3d 30 03 69 3d 30 05 62 | 69 74 3d 30 19 77 68 69 |=0.i=0.b|it=0.whi|
|00001d90| 6c 65 20 62 69 74 3d 30 | 20 61 6e 64 20 69 3c 6d |le bit=0| and i<m|
|00001da0| 61 78 65 2a 31 32 12 62 | 69 74 3d 6d 2e 67 65 74 |axe*12.b|it=m.get|
|00001db0| 4e 74 68 42 69 74 28 69 | 29 0d 49 66 20 62 69 74 |NthBit(i|).If bit|
|00001dc0| 3d 30 20 74 68 65 6e 0d | 63 6f 75 6e 74 3d 63 6f |=0 then.|count=co|
|00001dd0| 75 6e 74 2b 31 06 65 6e | 64 20 69 66 05 69 3d 69 |unt+1.en|d if.i=i|
|00001de0| 2b 31 04 77 65 6e 64 2b | 27 4d 73 67 42 6f 78 20 |+1.wend+|'MsgBox |
|00001df0| 22 6e 75 6d 62 65 72 20 | 6f 66 20 74 69 6d 65 73 |"number |of times|
|00001e00| 20 64 69 76 20 32 3d 22 | 2b 53 74 72 28 63 6f 75 | div 2="|+Str(cou|
|00001e10| 6e 74 29 08 6b 3d 63 6f | 75 6e 74 20 31 72 65 6d |nt).k=co|unt 1rem|
|00001e20| 20 66 69 6e 64 20 6d 3d | 20 6d 61 6e 74 69 73 73 | find m=| mantiss|
|00001e30| 61 20 3d 20 20 73 68 69 | 66 74 20 70 2d 31 20 72 |a = shi|ft p-1 r|
|00001e40| 69 67 68 74 20 62 79 20 | 6b 20 62 69 74 73 1b 46 |ight by |k bits.F|
|00001e50| 6f 72 20 69 3d 30 20 74 | 6f 20 70 72 65 63 69 73 |or i=0 t|o precis|
|00001e60| 69 6f 6e 2a 31 32 2d 6b | 2d 31 1f 6d 2e 53 65 74 |ion*12-k|-1.m.Set|
|00001e70| 4e 74 68 42 69 74 20 69 | 2c 20 6d 2e 47 65 74 4e |NthBit i|, m.GetN|
|00001e80| 74 68 42 69 74 28 69 2b | 6b 29 04 6e 65 78 74 26 |thBit(i+|k).next&|
|00001e90| 46 6f 72 20 69 3d 70 72 | 65 63 69 73 69 6f 6e 2a |For i=pr|ecision*|
|00001ea0| 31 32 2d 6b 20 74 6f 20 | 70 72 65 63 69 73 69 6f |12-k to |precisio|
|00001eb0| 6e 2a 31 32 2d 31 10 6d | 2e 53 65 74 4e 74 68 42 |n*12-1.m|.SetNthB|
|00001ec0| 69 74 20 69 2c 20 30 04 | 6e 65 78 74 25 27 4d 73 |it i, 0.|next%'Ms|
|00001ed0| 67 42 6f 78 20 22 6d 61 | 6e 74 69 73 73 61 20 69 |gBox "ma|ntissa i|
|00001ee0| 73 20 22 2b 6d 2e 4c 69 | 6e 74 74 6f 53 74 72 69 |s "+m.Li|nttoStri|
|00001ef0| 6e 67 1e 52 45 4d 20 64 | 6f 20 35 20 74 65 73 74 |ng.REM d|o 5 test|
|00001f00| 73 20 6f 66 20 52 61 62 | 69 6e 2d 4d 69 6c 6c 65 |s of Rab|in-Mille|
|00001f10| 72 03 62 3d 30 0a 70 72 | 69 6d 65 3d 74 72 75 65 |r.b=0.pr|ime=true|
|00001f20| 13 77 68 69 6c 65 20 62 | 3c 35 20 61 6e 64 20 70 |.while b|<5 and p|
|00001f30| 72 69 6d 65 32 42 6f 73 | 73 2e 53 74 61 74 69 63 |rime2Bos|s.Static|
|00001f40| 41 63 74 69 6f 6e 2e 54 | 65 78 74 3d 22 52 61 62 |Action.T|ext="Rab|
|00001f50| 69 6e 20 69 74 65 72 61 | 74 69 6f 6e 20 22 2b 53 |in itera|tion "+S|
|00001f60| 74 72 28 62 2b 31 29 2d | 72 65 6d 20 74 72 79 20 |tr(b+1)-|rem try |
|00001f70| 74 65 73 74 73 20 77 69 | 74 68 20 35 20 64 69 66 |tests wi|th 5 dif|
|00001f80| 66 65 72 65 6e 74 20 72 | 61 6e 64 6f 6d 20 6e 75 |ferent r|andom nu|
|00001f90| 6d 62 65 72 73 0b 70 72 | 69 6d 65 3d 66 61 6c 73 |mbers.pr|ime=fals|
|00001fa0| 65 03 6a 3d 30 36 72 65 | 6d 20 6a 20 69 73 20 52 |e.j=06re|m j is R|
|00001fb0| 61 62 69 6e 2d 4d 69 6c | 6c 65 72 20 69 74 65 72 |abin-Mil|ler iter|
|00001fc0| 61 74 69 6f 6e 20 66 6f | 72 20 65 61 63 68 20 72 |ation fo|r each r|
|00001fd0| 61 6e 64 6f 6d 20 6e 75 | 6d 62 65 72 26 52 45 4d |andom nu|mber&REM|
|00001fe0| 20 73 74 65 70 20 32 2e | 20 43 68 6f 6f 73 65 20 | step 2.| Choose |
|00001ff0| 61 20 72 61 6e 64 6f 6d | 20 6e 75 6d 62 65 72 20 |a random| number |
|00002000| 22 61 22 18 61 2e 73 65 | 74 20 31 2c 20 46 6c 6f |"a".a.se|t 1, Flo|
|00002010| 6f 72 28 72 6e 64 2a 34 | 30 39 36 29 18 61 2e 73 |or(rnd*4|096).a.s|
|00002020| 65 74 20 32 2c 20 46 6c | 6f 6f 72 28 72 6e 64 2a |et 2, Fl|oor(rnd*|
|00002030| 34 30 39 36 29 0a 61 2e | 6d 6f 64 75 6c 6f 20 70 |4096).a.|modulo p|
|00002040| 27 72 65 6d 20 61 20 69 | 73 20 61 20 72 61 6e 64 |'rem a i|s a rand|
|00002050| 6f 6d 20 6e 75 6d 62 65 | 72 20 73 6d 61 6c 6c 65 |om numbe|r smalle|
|00002060| 72 20 74 68 61 6e 20 70 | 09 7a 2e 65 71 75 61 6c |r than p|.z.equal|
|00002070| 20 61 1f 52 45 4d 20 53 | 74 65 70 20 33 2e 20 63 | a.REM S|tep 3. c|
|00002080| 6f 6d 70 75 74 65 20 7a | 3d 61 5e 6d 20 6d 6f 64 |ompute z|=a^m mod|
|00002090| 20 70 0c 7a 2e 65 78 70 | 6d 6f 64 20 6d 2c 70 09 | p.z.exp|mod m,p.|
|000020a0| 63 2e 65 71 75 61 6c 20 | 7a 0b 63 2e 64 65 63 72 |c.equal |z.c.decr|
|000020b0| 65 6d 65 6e 74 2e 52 45 | 4d 20 53 74 65 70 20 34 |ement.RE|M Step 4|
|000020c0| 2e 20 69 66 20 7a 20 69 | 73 20 65 71 75 61 6c 20 |. if z i|s equal |
|000020d0| 74 6f 20 31 20 74 68 65 | 6e 20 70 20 69 73 20 70 |to 1 the|n p is p|
|000020e0| 72 69 6d 65 10 69 66 20 | 63 2e 49 73 5a 65 72 6f |rime.if |c.IsZero|
|000020f0| 20 74 68 65 6e 0b 70 72 | 69 6d 65 3d 20 74 72 75 | then.pr|ime= tru|
|00002100| 65 04 65 6c 73 65 1b 52 | 45 4d 20 53 74 65 70 20 |e.else.R|EM Step |
|00002110| 35 2e 20 69 74 65 72 61 | 74 65 20 6b 20 74 69 6d |5. itera|te k tim|
|00002120| 65 73 03 6a 3d 30 17 77 | 68 69 6c 65 20 6a 3c 6b |es.j=0.w|hile j<k|
|00002130| 20 61 6e 64 20 6e 6f 74 | 20 70 72 69 6d 65 15 49 | and not| prime.I|
|00002140| 66 20 75 73 65 72 43 61 | 6e 63 65 6c 6c 65 64 20 |f userCa|ncelled |
|00002150| 74 68 65 6e 0c 72 65 74 | 75 72 6e 20 66 61 6c 73 |then.ret|urn fals|
|00002160| 65 06 65 6e 64 20 69 66 | 09 63 2e 65 71 75 61 6c |e.end if|.c.equal|
|00002170| 20 7a 08 63 2e 69 41 64 | 64 20 31 0a 63 2e 6d 6f | z.c.iAd|d 1.c.mo|
|00002180| 64 75 6c 6f 20 70 16 52 | 45 4d 20 69 73 20 7a 20 |dulo p.R|EM is z |
|00002190| 65 71 75 61 6c 20 74 6f | 20 70 2d 31 3f 2b 27 4d |equal to| p-1?+'M|
|000021a0| 73 67 42 6f 78 20 22 69 | 73 20 7a 20 65 71 75 61 |sgBox "i|s z equa|
|000021b0| 6c 20 74 6f 20 70 2d 31 | 3f 22 2b 63 2e 4c 69 6e |l to p-1|?"+c.Lin|
|000021c0| 74 74 6f 53 74 72 69 6e | 67 10 69 66 20 63 2e 49 |ttoStrin|g.if c.I|
|000021d0| 73 5a 65 72 6f 20 74 68 | 65 6e 0b 70 72 69 6d 65 |sZero th|en.prime|
|000021e0| 3d 20 74 72 75 65 05 65 | 6c 73 65 20 0c 7a 2e 4d |= true.e|lse .z.M|
|000021f0| 75 6c 74 69 70 6c 79 20 | 7a 0a 7a 2e 4d 6f 64 75 |ultiply |z.z.Modu|
|00002200| 6c 6f 20 70 06 65 6e 64 | 20 69 66 05 6a 3d 6a 2b |lo p.end| if.j=j+|
|00002210| 31 04 77 65 6e 64 06 65 | 6e 64 20 69 66 05 62 3d |1.wend.e|nd if.b=|
|00002220| 62 2b 31 04 77 65 6e 64 | 0c 72 65 74 75 72 6e 20 |b+1.wend|.return |
|00002230| 70 72 69 6d 65 0c 45 6e | 64 20 46 75 6e 63 74 69 |prime.En|d Functi|
|00002240| 6f 6e 09 63 61 6e 64 69 | 64 61 74 65 10 6e 62 69 |on.candi|date.nbi|
|00002250| 74 73 20 61 73 20 69 6e | 74 65 67 65 72 00 00 12 |ts as in|teger...|
|00002260| 04 12 04 ac 01 1f 53 75 | 62 20 63 61 6e 64 69 64 |......Su|b candid|
|00002270| 61 74 65 28 6e 62 69 74 | 73 20 61 73 20 69 6e 74 |ate(nbit|s as int|
|00002280| 65 67 65 72 29 2c 52 45 | 4d 20 67 65 6e 65 72 61 |eger),RE|M genera|
|00002290| 74 65 20 61 20 72 61 6e | 64 6f 6d 20 6e 75 6d 62 |te a ran|dom numb|
|000022a0| 65 72 20 61 6e 64 20 74 | 65 73 74 20 74 6f 20 73 |er and t|est to s|
|000022b0| 65 65 22 52 45 4d 20 69 | 66 20 73 6d 61 6c 6c 20 |ee"REM i|f small |
|000022c0| 70 72 69 6d 65 73 20 63 | 61 6e 20 64 69 76 69 64 |primes c|an divid|
|000022d0| 65 20 69 74 2e 35 52 45 | 4d 20 72 65 70 65 61 74 |e it.5RE|M repeat|
|000022e0| 20 75 6e 74 69 6c 20 69 | 74 20 69 73 20 70 72 69 | until i|t is pri|
|000022f0| 6d 65 20 72 65 6c 61 74 | 69 76 65 20 74 6f 20 73 |me relat|ive to s|
|00002300| 6d 61 6c 6c 20 70 72 69 | 6d 65 73 14 44 69 6d 20 |mall pri|mes.Dim |
|00002310| 70 72 69 6d 65 20 61 73 | 20 62 6f 6f 6c 65 61 6e |prime as| boolean|
|00002320| 11 44 69 6d 20 6d 20 61 | 73 20 4c 69 6e 74 65 67 |.Dim m a|s Linteg|
|00002330| 65 72 10 44 69 6d 20 69 | 20 61 73 20 69 6e 74 65 |er.Dim i| as inte|
|00002340| 67 65 72 0b 70 72 69 6d | 65 3d 66 61 6c 73 65 0e |ger.prim|e=false.|
|00002350| 6d 3d 6e 65 77 20 4c 69 | 6e 74 65 67 65 72 15 6d |m=new Li|nteger.m|
|00002360| 2e 70 72 65 63 69 73 69 | 6f 6e 3d 70 72 65 63 69 |.precisi|on=preci|
|00002370| 73 69 6f 6e 0f 77 68 69 | 6c 65 20 6e 6f 74 20 70 |sion.whi|le not p|
|00002380| 72 69 6d 65 0e 52 45 4d | 20 47 65 6e 65 72 61 74 |rime.REM| Generat|
|00002390| 65 20 70 26 42 6f 73 73 | 2e 53 74 61 74 69 63 41 |e p&Boss|.StaticA|
|000023a0| 63 74 69 6f 6e 2e 54 65 | 78 74 3d 22 6e 65 77 20 |ction.Te|xt="new |
|000023b0| 63 61 6e 64 69 64 61 74 | 65 22 0b 70 2e 72 61 6e |candidat|e".p.ran|
|000023c0| 64 6f 6d 69 7a 65 0f 70 | 2e 73 65 74 4e 74 68 42 |domize.p|.setNthB|
|000023d0| 69 74 20 30 2c 31 15 70 | 2e 73 65 74 4e 74 68 42 |it 0,1.p|.setNthB|
|000023e0| 69 74 20 6e 62 69 74 73 | 2d 31 2c 31 1d 46 6f 72 |it nbits|-1,1.For|
|000023f0| 20 69 3d 6e 62 69 74 73 | 20 74 6f 20 70 72 65 63 | i=nbits| to prec|
|00002400| 69 73 69 6f 6e 2a 31 32 | 2d 31 0f 70 2e 73 65 74 |ision*12|-1.p.set|
|00002410| 4e 74 68 42 69 74 20 69 | 2c 30 04 6e 65 78 74 1f |NthBit i|,0.next.|
|00002420| 52 45 4d 20 74 65 73 74 | 20 64 69 76 69 64 65 20 |REM test| divide |
|00002430| 62 79 20 73 6d 61 6c 6c | 20 70 72 69 6d 65 73 0a |by small| primes.|
|00002440| 70 72 69 6d 65 3d 74 72 | 75 65 09 6d 2e 65 71 75 |prime=tr|ue.m.equ|
|00002450| 61 6c 20 70 0b 6d 2e 49 | 6d 6f 64 75 6c 6f 20 33 |al p.m.I|modulo 3|
|00002460| 10 69 66 20 6d 2e 69 73 | 7a 65 72 6f 20 74 68 65 |.if m.is|zero the|
|00002470| 6e 0b 70 72 69 6d 65 3d | 66 61 6c 73 65 06 65 6e |n.prime=|false.en|
|00002480| 64 20 69 66 09 6d 2e 65 | 71 75 61 6c 20 70 0b 6d |d if.m.e|qual p.m|
|00002490| 2e 49 6d 6f 64 75 6c 6f | 20 35 10 69 66 20 6d 2e |.Imodulo| 5.if m.|
|000024a0| 69 73 7a 65 72 6f 20 74 | 68 65 6e 0b 70 72 69 6d |iszero t|hen.prim|
|000024b0| 65 3d 66 61 6c 73 65 06 | 65 6e 64 20 69 66 09 6d |e=false.|end if.m|
|000024c0| 2e 65 71 75 61 6c 20 70 | 0b 6d 2e 49 6d 6f 64 75 |.equal p|.m.Imodu|
|000024d0| 6c 6f 20 37 10 69 66 20 | 6d 2e 69 73 7a 65 72 6f |lo 7.if |m.iszero|
|000024e0| 20 74 68 65 6e 0b 70 72 | 69 6d 65 3d 66 61 6c 73 | then.pr|ime=fals|
|000024f0| 65 06 65 6e 64 20 69 66 | 09 6d 2e 65 71 75 61 6c |e.end if|.m.equal|
|00002500| 20 70 0c 6d 2e 49 6d 6f | 64 75 6c 6f 20 31 31 10 | p.m.Imo|dulo 11.|
|00002510| 69 66 20 6d 2e 69 73 7a | 65 72 6f 20 74 68 65 6e |if m.isz|ero then|
|00002520| 0b 70 72 69 6d 65 3d 66 | 61 6c 73 65 06 65 6e 64 |.prime=f|alse.end|
|00002530| 20 69 66 09 6d 2e 65 71 | 75 61 6c 20 70 0c 6d 2e | if.m.eq|ual p.m.|
|00002540| 49 6d 6f 64 75 6c 6f 20 | 31 33 10 69 66 20 6d 2e |Imodulo |13.if m.|
|00002550| 69 73 7a 65 72 6f 20 74 | 68 65 6e 0b 70 72 69 6d |iszero t|hen.prim|
|00002560| 65 3d 66 61 6c 73 65 06 | 65 6e 64 20 69 66 09 6d |e=false.|end if.m|
|00002570| 2e 65 71 75 61 6c 20 70 | 0c 6d 2e 49 6d 6f 64 75 |.equal p|.m.Imodu|
|00002580| 6c 6f 20 31 37 10 69 66 | 20 6d 2e 69 73 7a 65 72 |lo 17.if| m.iszer|
|00002590| 6f 20 74 68 65 6e 0b 70 | 72 69 6d 65 3d 66 61 6c |o then.p|rime=fal|
|000025a0| 73 65 06 65 6e 64 20 69 | 66 09 6d 2e 65 71 75 61 |se.end i|f.m.equa|
|000025b0| 6c 20 70 0c 6d 2e 49 6d | 6f 64 75 6c 6f 20 31 39 |l p.m.Im|odulo 19|
|000025c0| 10 69 66 20 6d 2e 69 73 | 7a 65 72 6f 20 74 68 65 |.if m.is|zero the|
|000025d0| 6e 0b 70 72 69 6d 65 3d | 66 61 6c 73 65 06 65 6e |n.prime=|false.en|
|000025e0| 64 20 69 66 09 6d 2e 65 | 71 75 61 6c 20 70 0c 6d |d if.m.e|qual p.m|
|000025f0| 2e 49 6d 6f 64 75 6c 6f | 20 32 33 10 69 66 20 6d |.Imodulo| 23.if m|
|00002600| 2e 69 73 7a 65 72 6f 20 | 74 68 65 6e 0b 70 72 69 |.iszero |then.pri|
|00002610| 6d 65 3d 66 61 6c 73 65 | 06 65 6e 64 20 69 66 09 |me=false|.end if.|
|00002620| 6d 2e 65 71 75 61 6c 20 | 70 0c 6d 2e 49 6d 6f 64 |m.equal |p.m.Imod|
|00002630| 75 6c 6f 20 32 39 10 69 | 66 20 6d 2e 69 73 7a 65 |ulo 29.i|f m.isze|
|00002640| 72 6f 20 74 68 65 6e 0b | 70 72 69 6d 65 3d 66 61 |ro then.|prime=fa|
|00002650| 6c 73 65 06 65 6e 64 20 | 69 66 09 6d 2e 65 71 75 |lse.end |if.m.equ|
|00002660| 61 6c 20 70 0c 6d 2e 49 | 6d 6f 64 75 6c 6f 20 33 |al p.m.I|modulo 3|
|00002670| 31 10 69 66 20 6d 2e 69 | 73 7a 65 72 6f 20 74 68 |1.if m.i|szero th|
|00002680| 65 6e 0b 70 72 69 6d 65 | 3d 66 61 6c 73 65 06 65 |en.prime|=false.e|
|00002690| 6e 64 20 69 66 09 6d 2e | 65 71 75 61 6c 20 70 0c |nd if.m.|equal p.|
|000026a0| 6d 2e 49 6d 6f 64 75 6c | 6f 20 33 37 10 69 66 20 |m.Imodul|o 37.if |
|000026b0| 6d 2e 69 73 7a 65 72 6f | 20 74 68 65 6e 0b 70 72 |m.iszero| then.pr|
|000026c0| 69 6d 65 3d 66 61 6c 73 | 65 06 65 6e 64 20 69 66 |ime=fals|e.end if|
|000026d0| 09 6d 2e 65 71 75 61 6c | 20 70 0c 6d 2e 49 6d 6f |.m.equal| p.m.Imo|
|000026e0| 64 75 6c 6f 20 34 31 10 | 69 66 20 6d 2e 69 73 7a |dulo 41.|if m.isz|
|000026f0| 65 72 6f 20 74 68 65 6e | 0b 70 72 69 6d 65 3d 66 |ero then|.prime=f|
|00002700| 61 6c 73 65 06 65 6e 64 | 20 69 66 09 6d 2e 65 71 |alse.end| if.m.eq|
|00002710| 75 61 6c 20 70 0c 6d 2e | 49 6d 6f 64 75 6c 6f 20 |ual p.m.|Imodulo |
|00002720| 34 33 10 69 66 20 6d 2e | 69 73 7a 65 72 6f 20 74 |43.if m.|iszero t|
|00002730| 68 65 6e 0b 70 72 69 6d | 65 3d 66 61 6c 73 65 06 |hen.prim|e=false.|
|00002740| 65 6e 64 20 69 66 09 6d | 2e 65 71 75 61 6c 20 70 |end if.m|.equal p|
|00002750| 0c 6d 2e 49 6d 6f 64 75 | 6c 6f 20 34 37 10 69 66 |.m.Imodu|lo 47.if|
|00002760| 20 6d 2e 69 73 7a 65 72 | 6f 20 74 68 65 6e 0b 70 | m.iszer|o then.p|
|00002770| 72 69 6d 65 3d 66 61 6c | 73 65 06 65 6e 64 20 69 |rime=fal|se.end i|
|00002780| 66 09 6d 2e 65 71 75 61 | 6c 20 70 0c 6d 2e 49 6d |f.m.equa|l p.m.Im|
|00002790| 6f 64 75 6c 6f 20 35 33 | 10 69 66 20 6d 2e 69 73 |odulo 53|.if m.is|
|000027a0| 7a 65 72 6f 20 74 68 65 | 6e 0b 70 72 69 6d 65 3d |zero the|n.prime=|
|000027b0| 66 61 6c 73 65 06 65 6e | 64 20 69 66 09 6d 2e 65 |false.en|d if.m.e|
|000027c0| 71 75 61 6c 20 70 0c 6d | 2e 49 6d 6f 64 75 6c 6f |qual p.m|.Imodulo|
|000027d0| 20 35 39 10 69 66 20 6d | 2e 69 73 7a 65 72 6f 20 | 59.if m|.iszero |
|000027e0| 74 68 65 6e 0b 70 72 69 | 6d 65 3d 66 61 6c 73 65 |then.pri|me=false|
|000027f0| 06 65 6e 64 20 69 66 09 | 6d 2e 65 71 75 61 6c 20 |.end if.|m.equal |
|00002800| 70 0c 6d 2e 49 6d 6f 64 | 75 6c 6f 20 36 31 10 69 |p.m.Imod|ulo 61.i|
|00002810| 66 20 6d 2e 69 73 7a 65 | 72 6f 20 74 68 65 6e 0b |f m.isze|ro then.|
|00002820| 70 72 69 6d 65 3d 66 61 | 6c 73 65 06 65 6e 64 20 |prime=fa|lse.end |
|00002830| 69 66 04 77 65 6e 64 07 | 45 6e 64 20 53 75 62 00 |if.wend.|End Sub.|
|00002840| 01 03 52 75 6e 0b 24 0b | 24 12 09 53 75 62 20 52 |..Run.$.|$..Sub R|
|00002850| 75 6e 28 29 8f 01 52 45 | 4d 20 67 65 6e 65 72 61 |un()..RE|M genera|
|00002860| 74 65 20 61 20 70 72 69 | 6d 65 20 6e 75 6d 62 65 |te a pri|me numbe|
|00002870| 72 2c 20 74 65 73 74 69 | 6e 67 20 66 6f 72 20 70 |r, testi|ng for p|
|00002880| 72 69 6d 61 6c 69 74 79 | 20 75 73 69 6e 67 20 74 |rimality| using t|
|00002890| 68 65 20 4d 69 6c 6c 65 | 72 2d 52 61 62 69 6e 20 |he Mille|r-Rabin |
|000028a0| 74 65 73 74 73 16 44 69 | 6d 20 63 6f 75 6e 74 65 |tests.Di|m counte|
|000028b0| 72 20 61 73 20 69 6e 74 | 65 67 65 72 30 70 72 65 |r as int|eger0pre|
|000028c0| 63 69 73 69 6f 6e 3d 63 | 65 69 6c 28 76 61 6c 28 |cision=c|eil(val(|
|000028d0| 42 6f 73 73 2e 45 64 69 | 74 50 72 65 63 69 73 69 |Boss.Edi|tPrecisi|
|000028e0| 6f 6e 2e 54 65 78 74 29 | 2f 34 2f 33 29 0e 70 3d |on.Text)|/4/3).p=|
|000028f0| 6e 65 77 20 4c 69 6e 74 | 65 67 65 72 10 70 2e 6e |new Lint|eger.p.n|
|00002900| 65 67 61 74 69 76 65 3d | 66 61 6c 73 65 15 70 2e |egative=|false.p.|
|00002910| 70 72 65 63 69 73 69 6f | 6e 3d 70 72 65 63 69 73 |precisio|n=precis|
|00002920| 69 6f 6e 26 63 61 6e 64 | 69 64 61 74 65 20 56 61 |ion&cand|idate Va|
|00002930| 6c 28 42 6f 73 73 2e 45 | 64 69 74 50 72 65 63 69 |l(Boss.E|ditPreci|
|00002940| 73 69 6f 6e 2e 54 65 78 | 74 29 09 63 6f 75 6e 74 |sion.Tex|t).count|
|00002950| 65 72 3d 31 22 42 6f 73 | 73 2e 54 72 69 61 6c 4e |er=1"Bos|s.TrialN|
|00002960| 75 6d 62 65 72 2e 54 65 | 78 74 3d 53 74 72 28 63 |umber.Te|xt=Str(c|
|00002970| 6f 75 6e 74 65 72 29 0f | 57 68 69 6c 65 20 6e 6f |ounter).|While no|
|00002980| 74 20 52 61 62 69 6e 83 | 01 63 61 6e 64 69 64 61 |t Rabin.|.candida|
|00002990| 74 65 20 56 61 6c 28 42 | 6f 73 73 2e 45 64 69 74 |te Val(B|oss.Edit|
|000029a0| 50 72 65 63 69 73 69 6f | 6e 2e 54 65 78 74 29 20 |Precisio|n.Text) |
|000029b0| 20 27 67 65 6e 65 72 61 | 74 65 20 61 20 70 72 69 | 'genera|te a pri|
|000029c0| 6d 65 20 63 61 6e 64 69 | 64 61 74 65 11 63 6f 75 |me candi|date.cou|
|000029d0| 6e 74 65 72 3d 63 6f 75 | 6e 74 65 72 2b 31 22 42 |nter=cou|nter+1"B|
|000029e0| 6f 73 73 2e 54 72 69 61 | 6c 4e 75 6d 62 65 72 2e |oss.Tria|lNumber.|
|000029f0| 54 65 78 74 3d 53 74 72 | 28 63 6f 75 6e 74 65 72 |Text=Str|(counter|
|00002a00| 29 04 77 65 6e 64 1d 42 | 6f 73 73 2e 53 74 61 74 |).wend.B|oss.Stat|
|00002a10| 69 63 41 63 74 69 6f 6e | 2e 54 65 78 74 3d 22 69 |icAction|.Text="i|
|00002a20| 64 6c 65 22 87 01 42 6f | 73 73 2e 45 64 69 74 50 |dle"..Bo|ss.EditP|
|00002a30| 72 69 6d 65 2e 74 65 78 | 74 3d 42 6f 73 73 2e 45 |rime.tex|t=Boss.E|
|00002a40| 64 69 74 50 72 69 6d 65 | 2e 74 65 78 74 2b 22 50 |ditPrime|.text+"P|
|00002a50| 72 69 6d 65 3a 22 2b 70 | 2e 4c 69 6e 74 74 6f 53 |rime:"+p|.LinttoS|
|00002a60| 74 72 69 6e 67 2b 63 68 | 72 28 31 33 29 07 45 6e |tring+ch|r(13).En|
|00002a70| 64 20 53 75 62 00 00 00 | 06 41 05 43 6c 61 73 73 |d Sub...|.A.Class|
|00002a80| 08 4c 69 6e 74 65 67 65 | 72 a3 01 34 ba 0f bd 0a |.Lintege|r..4....|
|00002a90| 07 00 08 4c 69 6e 74 65 | 67 65 72 19 00 00 03 17 |...Linte|ger.....|
|00002aa0| 69 61 72 72 61 79 28 31 | 30 32 34 29 20 61 73 20 |iarray(1|024) as |
|00002ab0| 69 6e 74 65 67 65 72 00 | 14 70 72 65 63 69 73 69 |integer.|.precisi|
|00002ac0| 6f 6e 20 61 73 20 69 6e | 74 65 67 65 72 00 13 6e |on as in|teger..n|
|00002ad0| 65 67 61 74 69 76 65 20 | 61 73 20 62 6f 6f 6c 65 |egative |as boole|
|00002ae0| 61 6e 00 1a 08 4d 75 6c | 74 69 70 6c 79 0d 62 20 |an...Mul|tiply.b |
|00002af0| 61 73 20 4c 69 6e 74 65 | 67 65 72 00 00 33 04 33 |as Linte|ger..3.3|
|00002b00| 04 3e 1b 53 75 62 20 4d | 75 6c 74 69 70 6c 79 28 |.>.Sub M|ultiply(|
|00002b10| 62 20 61 73 20 4c 69 6e | 74 65 67 65 72 29 13 52 |b as Lin|teger).R|
|00002b20| 45 4d 20 43 61 6c 63 75 | 6c 61 74 65 20 61 3d 61 |EM Calcu|late a=a|
|00002b30| 2a 62 17 44 69 6d 20 69 | 2c 6b 2c 68 2c 20 6e 20 |*b.Dim i|,k,h, n |
|00002b40| 61 73 20 69 6e 74 65 67 | 65 72 13 44 69 6d 20 6d |as integ|er.Dim m|
|00002b50| 61 78 6b 20 61 73 20 69 | 6e 74 65 67 65 72 13 44 |axk as i|nteger.D|
|00002b60| 69 6d 20 6d 61 78 69 20 | 61 73 20 69 6e 74 65 67 |im maxi |as integ|
|00002b70| 65 72 19 44 69 6d 20 74 | 65 6d 70 28 31 30 32 34 |er.Dim t|emp(1024|
|00002b80| 29 20 61 73 20 69 6e 74 | 65 67 65 72 15 44 69 6d |) as int|eger.Dim|
|00002b90| 20 63 61 72 72 79 20 20 | 61 73 20 69 6e 74 65 67 | carry |as integ|
|00002ba0| 65 72 2d 52 45 4d 20 65 | 76 61 6c 75 61 74 65 20 |er-REM e|valuate |
|00002bb0| 74 68 65 20 6e 75 6d 62 | 65 72 20 6f 66 20 73 69 |the numb|er of si|
|00002bc0| 67 6e 69 66 69 63 61 6e | 74 20 64 69 67 69 74 73 |gnifican|t digits|
|00002bd0| 3e 52 45 4d 20 74 68 69 | 73 20 74 61 6b 65 73 20 |>REM thi|s takes |
|00002be0| 6c 69 6e 65 61 72 20 74 | 69 6d 65 2c 20 77 68 65 |linear t|ime, whe|
|00002bf0| 72 65 61 73 20 6d 75 6c | 74 69 70 6c 79 20 74 61 |reas mul|tiply ta|
|00002c00| 6b 65 73 20 73 71 75 61 | 72 65 20 74 69 6d 65 04 |kes squa|re time.|
|00002c10| 52 45 4d 20 0e 6d 61 78 | 69 3d 70 72 65 63 69 73 |REM .max|i=precis|
|00002c20| 69 6f 6e 20 77 68 69 6c | 65 20 69 61 72 72 61 79 |ion whil|e iarray|
|00002c30| 28 6d 61 78 69 29 3d 30 | 20 20 61 6e 64 20 6d 61 |(maxi)=0| and ma|
|00002c40| 78 69 3e 30 0b 6d 61 78 | 69 3d 6d 61 78 69 2d 31 |xi>0.max|i=maxi-1|
|00002c50| 04 77 65 6e 64 0e 6d 61 | 78 6b 3d 70 72 65 63 69 |.wend.ma|xk=preci|
|00002c60| 73 69 6f 6e 21 77 68 69 | 6c 65 20 62 2e 69 61 72 |sion!whi|le b.iar|
|00002c70| 72 61 79 28 6d 61 78 6b | 29 3d 30 20 61 6e 64 20 |ray(maxk|)=0 and |
|00002c80| 6d 61 78 6b 3e 30 0b 6d | 61 78 6b 3d 6d 61 78 6b |maxk>0.m|axk=maxk|
|00002c90| 2d 31 04 77 65 6e 64 1c | 69 66 20 70 72 65 63 69 |-1.wend.|if preci|
|00002ca0| 73 69 6f 6e 3c 20 6d 61 | 78 6b 2b 6d 61 78 69 20 |sion< ma|xk+maxi |
|00002cb0| 74 68 65 6e 21 70 72 65 | 63 69 73 69 6f 6e 3d 49 |then!pre|cision=I|
|00002cc0| 6e 74 4d 69 6e 28 31 30 | 32 34 2c 20 6d 61 78 6b |ntMin(10|24, maxk|
|00002cd0| 2b 6d 61 78 69 29 07 65 | 6e 64 20 69 66 20 15 52 |+maxi).e|nd if .R|
|00002ce0| 45 4d 20 73 74 61 72 74 | 20 6d 75 6c 74 69 70 6c |EM start| multipl|
|00002cf0| 79 69 6e 67 07 63 61 72 | 72 79 3d 30 1b 69 66 20 |ying.car|ry=0.if |
|00002d00| 6d 61 78 69 2b 6d 61 78 | 6b 3e 70 72 65 63 69 73 |maxi+max|k>precis|
|00002d10| 69 6f 6e 20 74 68 65 6e | 26 4d 73 67 42 6f 78 20 |ion then|&MsgBox |
|00002d20| 22 4d 75 6c 74 69 70 6c | 69 63 61 74 69 6f 6e 20 |"Multipl|ication |
|00002d30| 6f 76 65 72 66 6c 6f 77 | 20 65 72 72 6f 72 22 06 |overflow| error".|
|00002d40| 72 65 74 75 72 6e 06 65 | 6e 64 20 69 66 10 46 6f |return.e|nd if.Fo|
|00002d50| 72 20 69 3d 20 31 20 74 | 6f 20 6d 61 78 69 14 69 |r i= 1 t|o maxi.i|
|00002d60| 66 20 69 61 72 72 61 79 | 28 69 29 3e 30 20 74 68 |f iarray|(i)>0 th|
|00002d70| 65 6e 20 19 52 45 4d 20 | 6d 75 6c 74 69 70 6c 79 |en .REM |multiply|
|00002d80| 20 62 79 20 69 61 72 72 | 61 79 28 69 29 26 46 6f | by iarr|ay(i)&Fo|
|00002d90| 72 20 6b 3d 31 20 74 6f | 20 49 6e 74 4d 69 6e 28 |r k=1 to| IntMin(|
|00002da0| 6d 61 78 6b 2c 20 70 72 | 65 63 69 73 69 6f 6e 2d |maxk, pr|ecision-|
|00002db0| 69 2b 31 29 33 74 65 6d | 70 28 69 2b 6b 2d 31 29 |i+1)3tem|p(i+k-1)|
|00002dc0| 3d 74 65 6d 70 28 69 2b | 6b 2d 31 29 2b 69 61 72 |=temp(i+|k-1)+iar|
|00002dd0| 72 61 79 28 69 29 2a 62 | 2e 69 61 72 72 61 79 28 |ray(i)*b|.iarray(|
|00002de0| 6b 29 2b 63 61 72 72 79 | 17 63 61 72 72 79 3d 20 |k)+carry|.carry= |
|00002df0| 74 65 6d 70 28 69 2b 6b | 2d 31 29 5c 34 30 39 36 |temp(i+k|-1)\4096|
|00002e00| 28 74 65 6d 70 28 69 2b | 6b 2d 31 29 3d 42 69 74 |(temp(i+|k-1)=Bit|
|00002e10| 77 69 73 65 41 6e 64 28 | 74 65 6d 70 28 69 2b 6b |wiseAnd(|temp(i+k|
|00002e20| 2d 31 29 2c 34 30 39 35 | 29 29 52 45 4d 20 62 69 |-1),4095|))REM bi|
|00002e30| 74 77 69 73 65 61 6e 64 | 20 69 73 20 74 68 65 20 |twiseand| is the |
|00002e40| 73 61 6d 65 20 61 73 20 | 6d 6f 64 75 6c 6f 20 34 |same as |modulo 4|
|00002e50| 30 39 36 04 6e 65 78 74 | 16 52 45 4d 20 74 61 6b |096.next|.REM tak|
|00002e60| 65 20 63 61 72 65 20 6f | 66 20 63 61 72 72 79 1d |e care o|f carry.|
|00002e70| 6b 3d 49 6e 74 4d 69 6e | 28 6d 61 78 6b 2c 20 70 |k=IntMin|(maxk, p|
|00002e80| 72 65 63 69 73 69 6f 6e | 2d 69 2b 31 29 03 6e 3d |recision|-i+1).n=|
|00002e90| 30 23 77 68 69 6c 65 20 | 63 61 72 72 79 3e 30 20 |0#while |carry>0 |
|00002ea0| 61 6e 64 20 20 69 2b 6b | 2b 6e 3c 3d 70 72 65 63 |and i+k|+n<=prec|
|00002eb0| 69 73 69 6f 6e 1d 74 65 | 6d 70 28 69 2b 6b 2b 6e |ision.te|mp(i+k+n|
|00002ec0| 29 3d 74 65 6d 70 28 69 | 2b 6b 2b 6e 29 2b 63 61 |)=temp(i|+k+n)+ca|
|00002ed0| 72 72 79 17 63 61 72 72 | 79 3d 20 74 65 6d 70 28 |rry.carr|y= temp(|
|00002ee0| 69 2b 6b 2b 6e 29 5c 34 | 30 39 36 28 74 65 6d 70 |i+k+n)\4|096(temp|
|00002ef0| 28 69 2b 6b 2b 6e 29 3d | 42 69 74 77 69 73 65 41 |(i+k+n)=|BitwiseA|
|00002f00| 6e 64 28 74 65 6d 70 28 | 69 2b 6b 2b 6e 29 2c 34 |nd(temp(|i+k+n),4|
|00002f10| 30 39 35 29 05 6e 3d 6e | 2b 31 04 77 65 6e 64 0f |095).n=n|+1.wend.|
|00002f20| 49 66 20 63 61 72 72 79 | 3e 30 20 74 68 65 6e 26 |If carry|>0 then&|
|00002f30| 4d 73 67 42 6f 78 20 22 | 4d 75 6c 74 69 70 6c 69 |MsgBox "|Multipli|
|00002f40| 63 61 74 69 6f 6e 20 6f | 76 65 72 66 6c 6f 77 20 |cation o|verflow |
|00002f50| 65 72 72 6f 72 22 06 72 | 65 74 75 72 6e 06 65 6e |error".r|eturn.en|
|00002f60| 64 20 69 66 07 63 61 72 | 72 79 3d 30 06 65 6e 64 |d if.car|ry=0.end|
|00002f70| 20 69 66 04 6e 65 78 74 | 0f 46 6f 72 20 69 3d 31 | if.next|.For i=1|
|00002f80| 20 74 6f 20 31 30 32 34 | 12 69 61 72 72 61 79 28 | to 1024|.iarray(|
|00002f90| 69 29 3d 74 65 6d 70 28 | 69 29 20 04 6e 65 78 74 |i)=temp(|i) .next|
|00002fa0| 15 52 45 4d 20 74 61 6b | 65 20 63 61 72 65 20 6f |.REM tak|e care o|
|00002fb0| 66 20 73 69 67 6e 8b 01 | 69 66 20 28 6e 65 67 61 |f sign..|if (nega|
|00002fc0| 74 69 76 65 20 61 6e 64 | 20 62 2e 6e 65 67 61 74 |tive and| b.negat|
|00002fd0| 69 76 65 29 20 6f 72 20 | 28 28 6e 6f 74 20 6e 65 |ive) or |((not ne|
|00002fe0| 67 61 74 69 76 65 29 20 | 61 6e 64 20 28 6e 6f 74 |gative) |and (not|
|00002ff0| 20 62 2e 6e 65 67 61 74 | 69 76 65 29 29 20 74 68 | b.negat|ive)) th|
|00003000| 65 6e 20 0e 6e 65 67 61 | 74 69 76 65 3d 66 61 6c |en .nega|tive=fal|
|00003010| 73 65 05 65 6c 73 65 20 | 0d 6e 65 67 61 74 69 76 |se.else |.negativ|
|00003020| 65 3d 74 72 75 65 06 65 | 6e 64 20 69 66 07 45 6e |e=true.e|nd if.En|
|00003030| 64 20 53 75 62 03 73 65 | 74 1e 69 6e 64 65 78 20 |d Sub.se|t.index |
|00003040| 61 73 20 69 6e 74 65 67 | 65 72 2c 20 6b 20 61 73 |as integ|er, k as|
|00003050| 20 69 6e 74 65 67 65 72 | 00 00 06 0f 06 0f 0a 27 | integer|.......'|
|00003060| 53 75 62 20 73 65 74 28 | 69 6e 64 65 78 20 61 73 |Sub set(|index as|
|00003070| 20 69 6e 74 65 67 65 72 | 2c 20 6b 20 61 73 20 69 | integer|, k as i|
|00003080| 6e 74 65 67 65 72 29 16 | 69 66 20 70 72 65 63 69 |nteger).|if preci|
|00003090| 73 69 6f 6e 3e 31 30 32 | 34 20 74 68 65 6e 1b 4d |sion>102|4 then.M|
|000030a0| 73 67 42 6f 78 20 22 50 | 72 65 63 69 73 69 6f 6e |sgBox "P|recision|
|000030b0| 20 74 6f 6f 20 68 69 67 | 68 22 06 72 65 74 75 72 | too hig|h".retur|
|000030c0| 6e 06 65 6e 64 20 69 66 | 18 69 66 20 70 72 65 63 |n.end if|.if prec|
|000030d0| 69 73 69 6f 6e 3c 69 6e | 64 65 78 20 74 68 65 6e |ision<in|dex then|
|000030e0| 20 0f 70 72 65 63 69 73 | 69 6f 6e 3d 69 6e 64 65 | .precis|ion=inde|
|000030f0| 78 06 65 6e 64 20 69 66 | 0f 69 61 72 72 61 79 28 |x.end if|.iarray(|
|00003100| 69 6e 64 65 78 29 3d 6b | 07 45 6e 64 20 53 75 62 |index)=k|.End Sub|
|00003110| 05 65 71 75 61 6c 0d 62 | 20 61 73 20 4c 69 6e 74 |.equal.b| as Lint|
|00003120| 65 67 65 72 00 00 01 26 | 01 26 10 18 53 75 62 20 |eger...&|.&..Sub |
|00003130| 65 71 75 61 6c 28 62 20 | 61 73 20 4c 69 6e 74 65 |equal(b |as Linte|
|00003140| 67 65 72 29 26 52 45 4d | 20 20 6d 61 6b 65 20 6f |ger)&REM| make o|
|00003150| 6e 65 20 4c 69 6e 74 65 | 67 65 72 20 65 71 75 61 |ne Linte|ger equa|
|00003160| 6c 20 74 68 65 20 6f 74 | 68 65 72 10 44 69 6d 20 |l the ot|her.Dim |
|00003170| 69 20 61 73 20 69 6e 74 | 65 67 65 72 16 46 6f 72 |i as int|eger.For|
|00003180| 20 69 3d 31 20 74 6f 20 | 62 2e 70 72 65 63 69 73 | i=1 to |b.precis|
|00003190| 69 6f 6e 15 69 61 72 72 | 61 79 28 69 29 3d 62 2e |ion.iarr|ay(i)=b.|
|000031a0| 69 61 72 72 61 79 28 69 | 29 04 6e 65 78 74 1e 69 |iarray(i|).next.i|
|000031b0| 66 20 70 72 65 63 69 73 | 69 6f 6e 3c 62 2e 70 72 |f precis|ion<b.pr|
|000031c0| 65 63 69 73 69 6f 6e 20 | 74 68 65 6e 20 15 70 72 |ecision |then .pr|
|000031d0| 65 63 69 73 69 6f 6e 3d | 62 2e 70 72 65 63 69 73 |ecision=|b.precis|
|000031e0| 69 6f 6e 06 65 6e 64 20 | 69 66 1d 69 66 20 70 72 |ion.end |if.if pr|
|000031f0| 65 63 69 73 69 6f 6e 3e | 62 2e 70 72 65 63 69 73 |ecision>|b.precis|
|00003200| 69 6f 6e 20 74 68 65 6e | 20 66 6f 72 20 69 3d 62 |ion then| for i=b|
|00003210| 2e 70 72 65 63 69 73 69 | 6f 6e 2b 31 20 74 6f 20 |.precisi|on+1 to |
|00003220| 70 72 65 63 69 73 69 6f | 6e 0b 69 61 72 72 61 79 |precisio|n.iarray|
|00003230| 28 69 29 3d 30 04 6e 65 | 78 74 06 65 6e 64 20 69 |(i)=0.ne|xt.end i|
|00003240| 66 13 6e 65 67 61 74 69 | 76 65 3d 62 2e 6e 65 67 |f.negati|ve=b.neg|
|00003250| 61 74 69 76 65 07 45 6e | 64 20 53 75 62 06 44 69 |ative.En|d Sub.Di|
|00003260| 76 69 64 65 0d 62 20 61 | 73 20 4c 69 6e 74 65 67 |vide.b a|s Linteg|
|00003270| 65 72 00 00 0a 00 0d 00 | 8f 01 19 53 75 62 20 44 |er......|...Sub D|
|00003280| 69 76 69 64 65 28 62 20 | 61 73 20 4c 69 6e 74 65 |ivide(b |as Linte|
|00003290| 67 65 72 29 10 44 69 6d | 20 69 20 61 73 20 69 6e |ger).Dim| i as in|
|000032a0| 74 65 67 65 72 18 44 69 | 6d 20 70 6c 61 63 65 73 |teger.Di|m places|
|000032b0| 2c 20 6d 20 61 73 20 69 | 6e 74 65 67 65 72 13 44 |, m as i|nteger.D|
|000032c0| 69 6d 20 63 2c 64 20 61 | 73 20 4c 69 6e 74 65 67 |im c,d a|s Linteg|
|000032d0| 65 72 19 44 69 6d 20 6d | 61 78 69 2c 20 6d 61 78 |er.Dim m|axi, max|
|000032e0| 6b 20 61 73 20 69 6e 74 | 65 67 65 72 39 52 45 4d |k as int|eger9REM|
|000032f0| 20 20 46 6f 72 20 66 61 | 73 74 20 72 65 73 70 6f | For fa|st respo|
|00003300| 6e 73 65 2c 20 72 65 74 | 75 72 6e 20 7a 65 72 6f |nse, ret|urn zero|
|00003310| 20 69 66 20 64 69 76 69 | 64 65 72 20 69 73 20 67 | if divi|der is g|
|00003320| 72 65 61 74 65 72 16 69 | 66 20 6e 6f 74 20 47 72 |reater.i|f not Gr|
|00003330| 65 61 74 65 72 28 62 29 | 20 74 68 65 6e 04 7a 65 |eater(b)| then.ze|
|00003340| 72 6f 06 72 65 74 75 72 | 6e 06 65 6e 64 20 69 66 |ro.retur|n.end if|
|00003350| 2d 52 45 4d 20 65 76 61 | 6c 75 61 74 65 20 74 68 |-REM eva|luate th|
|00003360| 65 20 6e 75 6d 62 65 72 | 20 6f 66 20 73 69 67 6e |e number| of sign|
|00003370| 69 66 69 63 61 6e 74 20 | 64 69 67 69 74 73 3c 52 |ificant |digits<R|
|00003380| 45 4d 20 74 68 69 73 20 | 74 61 6b 65 73 20 6c 69 |EM this |takes li|
|00003390| 6e 65 61 72 20 74 69 6d | 65 2c 20 77 68 65 72 65 |near tim|e, where|
|000033a0| 61 73 20 64 69 76 69 64 | 65 20 74 61 6b 65 73 20 |as divid|e takes |
|000033b0| 73 71 75 61 72 65 20 74 | 69 6d 65 04 52 45 4d 20 |square t|ime.REM |
|000033c0| 0e 6d 61 78 69 3d 70 72 | 65 63 69 73 69 6f 6e 1f |.maxi=pr|ecision.|
|000033d0| 77 68 69 6c 65 20 69 61 | 72 72 61 79 28 6d 61 78 |while ia|rray(max|
|000033e0| 69 29 3d 30 20 61 6e 64 | 20 6d 61 78 69 3e 31 0b |i)=0 and| maxi>1.|
|000033f0| 6d 61 78 69 3d 6d 61 78 | 69 2d 31 04 77 65 6e 64 |maxi=max|i-1.wend|
|00003400| 0e 69 66 20 6d 61 78 69 | 3d 30 20 74 68 65 6e 26 |.if maxi|=0 then&|
|00003410| 72 65 74 75 72 6e 20 27 | 20 30 20 64 69 76 69 64 |return '| 0 divid|
|00003420| 65 64 20 62 79 20 61 6e | 79 74 68 69 6e 67 20 69 |ed by an|ything i|
|00003430| 73 20 7a 65 72 6f 06 65 | 6e 64 20 69 66 0e 6d 61 |s zero.e|nd if.ma|
|00003440| 78 6b 3d 70 72 65 63 69 | 73 69 6f 6e 22 77 68 69 |xk=preci|sion"whi|
|00003450| 6c 65 20 62 2e 69 61 72 | 72 61 79 28 6d 61 78 6b |le b.iar|ray(maxk|
|00003460| 29 3d 30 20 61 6e 64 20 | 6d 61 78 6b 20 3e 31 0b |)=0 and |maxk >1.|
|00003470| 6d 61 78 6b 3d 6d 61 78 | 6b 2d 31 04 77 65 6e 64 |maxk=max|k-1.wend|
|00003480| 0e 69 66 20 6d 61 78 6b | 3d 30 20 74 68 65 6e 19 |.if maxk|=0 then.|
|00003490| 4d 73 67 42 6f 78 20 22 | 44 69 76 69 73 69 6f 6e |MsgBox "|Division|
|000034a0| 20 62 79 20 7a 65 72 6f | 22 06 72 65 74 75 72 6e | by zero|".return|
|000034b0| 06 65 6e 64 20 69 66 29 | 52 45 4d 20 64 20 69 73 |.end if)|REM d is|
|000034c0| 20 74 68 65 20 72 65 6d | 61 69 6e 64 65 72 20 6f | the rem|ainder o|
|000034d0| 66 20 74 68 65 20 73 75 | 62 74 72 61 63 74 69 6f |f the su|btractio|
|000034e0| 6e 26 52 45 4d 20 63 20 | 69 73 20 6d 2a 62 2c 20 |n&REM c |is m*b, |
|000034f0| 61 6e 64 20 69 73 20 73 | 75 62 74 72 61 63 74 65 |and is s|ubtracte|
|00003500| 64 20 66 72 6f 6d 20 64 | 30 70 6c 61 63 65 73 3d |d from d|0places=|
|00003510| 6d 61 78 69 2d 6d 61 78 | 6b 20 27 4e 75 6d 62 65 |maxi-max|k 'Numbe|
|00003520| 72 20 6f 66 20 64 69 67 | 69 74 73 20 6f 66 20 72 |r of dig|its of r|
|00003530| 65 73 75 6c 74 2c 20 2d | 31 0f 63 3d 20 6e 65 77 |esult, -|1.c= new|
|00003540| 20 4c 69 6e 74 65 67 65 | 72 0f 64 3d 20 6e 65 77 | Lintege|r.d= new|
|00003550| 20 4c 69 6e 74 65 67 65 | 72 14 46 6f 72 20 69 3d | Lintege|r.For i=|
|00003560| 31 20 74 6f 20 70 72 65 | 63 69 73 69 6f 6e 15 64 |1 to pre|cision.d|
|00003570| 2e 69 61 72 72 61 79 28 | 69 29 3d 69 61 72 72 61 |.iarray(|i)=iarra|
|00003580| 79 28 69 29 04 6e 65 78 | 74 15 64 2e 70 72 65 63 |y(i).nex|t.d.prec|
|00003590| 69 73 69 6f 6e 3d 70 72 | 65 63 69 73 69 6f 6e 15 |ision=pr|ecision.|
|000035a0| 63 2e 70 72 65 63 69 73 | 69 6f 6e 3d 70 72 65 63 |c.precis|ion=prec|
|000035b0| 69 73 69 6f 6e 04 7a 65 | 72 6f 1c 52 45 4d 20 74 |ision.ze|ro.REM t|
|000035c0| 68 65 20 66 61 63 74 6f | 72 20 6d 20 69 73 20 67 |he facto|r m is g|
|000035d0| 75 65 73 73 65 64 20 2c | 6d 3d 64 2e 69 61 72 72 |uessed ,|m=d.iarr|
|000035e0| 61 79 28 6d 61 78 69 29 | 5c 62 2e 69 61 72 72 61 |ay(maxi)|\b.iarra|
|000035f0| 79 28 6d 61 78 6b 29 20 | 27 46 69 72 73 74 20 67 |y(maxk) |'First g|
|00003600| 75 65 73 73 0e 69 66 20 | 6d 61 78 6b 3e 31 20 74 |uess.if |maxk>1 t|
|00003610| 68 65 6e 8f 01 6d 3d 28 | 64 2e 69 61 72 72 61 79 |hen..m=(|d.iarray|
|00003620| 28 6d 61 78 69 29 2a 34 | 30 39 36 2b 64 2e 69 61 |(maxi)*4|096+d.ia|
|00003630| 72 72 61 79 28 6d 61 78 | 69 2d 31 29 29 5c 28 62 |rray(max|i-1))\(b|
|00003640| 2e 69 61 72 72 61 79 28 | 6d 61 78 6b 29 2a 34 30 |.iarray(|maxk)*40|
|00003650| 39 36 2b 62 2e 69 61 72 | 72 61 79 28 6d 61 78 6b |96+b.iar|ray(maxk|
|00003660| 2d 31 29 29 0d 20 27 46 | 69 72 73 74 20 67 75 65 |-1)). 'F|irst gue|
|00003670| 73 73 06 65 6e 64 20 69 | 66 10 57 68 69 6c 65 20 |ss.end i|f.While |
|00003680| 70 6c 61 63 65 73 3e 3d | 30 20 09 63 2e 45 71 75 |places>=|0 .c.Equ|
|00003690| 61 6c 20 62 0f 63 2e 53 | 68 69 66 74 4c 20 70 6c |al b.c.S|hiftL pl|
|000036a0| 61 63 65 73 13 27 4d 73 | 67 62 6f 78 20 22 6d 3d |aces.'Ms|gbox "m=|
|000036b0| 22 2b 53 74 72 28 6d 29 | 0d 63 2e 49 6d 75 6c 74 |"+Str(m)|.c.Imult|
|000036c0| 69 70 6c 79 20 6d 17 27 | 4d 73 67 42 6f 78 20 20 |iply m.'|MsgBox |
|000036d0| 63 2e 4c 69 6e 74 74 6f | 53 74 72 69 6e 67 29 77 |c.Lintto|String)w|
|000036e0| 68 69 6c 65 20 6e 6f 74 | 20 64 2e 47 72 65 61 74 |hile not| d.Great|
|000036f0| 65 72 28 63 29 20 27 47 | 75 65 73 73 20 69 73 20 |er(c) 'G|uess is |
|00003700| 74 6f 6f 20 68 69 67 68 | 23 27 4d 73 67 42 6f 78 |too high|#'MsgBox|
|00003710| 20 22 47 75 65 73 73 20 | 69 73 20 74 6f 6f 20 68 | "Guess |is too h|
|00003720| 69 67 68 3a 22 2b 53 74 | 72 28 6d 29 05 6d 3d 6d |igh:"+St|r(m).m=m|
|00003730| 2d 31 09 63 2e 45 71 75 | 61 6c 20 62 0f 63 2e 53 |-1.c.Equ|al b.c.S|
|00003740| 68 69 66 74 4c 20 70 6c | 61 63 65 73 0d 63 2e 49 |hiftL pl|aces.c.I|
|00003750| 6d 75 6c 74 69 70 6c 79 | 20 6d 17 27 4d 73 67 42 |multiply| m.'MsgB|
|00003760| 6f 78 20 20 63 2e 4c 69 | 6e 74 74 6f 53 74 72 69 |ox c.Li|nttoStri|
|00003770| 6e 67 04 77 65 6e 64 0c | 64 2e 53 75 62 74 72 61 |ng.wend.|d.Subtra|
|00003780| 63 74 20 63 12 69 61 72 | 72 61 79 28 70 6c 61 63 |ct c.iar|ray(plac|
|00003790| 65 73 2b 31 29 3d 6d 0f | 70 6c 61 63 65 73 3d 70 |es+1)=m.|places=p|
|000037a0| 6c 61 63 65 73 2d 31 0b | 6d 61 78 69 3d 6d 61 78 |laces-1.|maxi=max|
|000037b0| 69 2d 31 0f 69 66 20 6d | 61 78 6b 3e 31 20 74 68 |i-1.if m|axk>1 th|
|000037c0| 65 6e 20 0e 69 66 20 6d | 61 78 69 3e 31 20 74 68 |en .if m|axi>1 th|
|000037d0| 65 6e be 01 6d 3d 66 6c | 6f 6f 72 28 28 64 2e 69 |en..m=fl|oor((d.i|
|000037e0| 61 72 72 61 79 28 6d 61 | 78 69 2b 31 29 2a 31 36 |array(ma|xi+1)*16|
|000037f0| 37 37 37 32 31 36 2e 30 | 2b 64 2e 69 61 72 72 61 |777216.0|+d.iarra|
|00003800| 79 28 6d 61 78 69 29 2a | 34 30 39 36 2e 30 2b 64 |y(maxi)*|4096.0+d|
|00003810| 2e 69 61 72 72 61 79 28 | 6d 61 78 69 2d 31 29 29 |.iarray(|maxi-1))|
|00003820| 2f 28 62 2e 69 61 72 72 | 61 79 28 6d 61 78 6b 29 |/(b.iarr|ay(maxk)|
|00003830| 2a 34 30 39 36 2e 30 2b | 62 2e 69 61 72 72 61 79 |*4096.0+|b.iarray|
|00003840| 28 6d 61 78 6b 2d 31 29 | 29 29 20 27 20 67 75 65 |(maxk-1)|)) ' gue|
|00003850| 73 73 04 65 6c 73 65 ad | 01 6d 3d 66 6c 6f 6f 72 |ss.else.|.m=floor|
|00003860| 28 28 64 2e 69 61 72 72 | 61 79 28 6d 61 78 69 2b |((d.iarr|ay(maxi+|
|00003870| 31 29 2a 31 36 37 37 37 | 32 31 36 2e 30 2b 64 2e |1)*16777|216.0+d.|
|00003880| 69 61 72 72 61 79 28 6d | 61 78 69 29 2a 34 30 39 |iarray(m|axi)*409|
|00003890| 36 2e 30 29 2f 28 62 2e | 69 61 72 72 61 79 28 6d |6.0)/(b.|iarray(m|
|000038a0| 61 78 6b 29 2a 34 30 39 | 36 2e 30 2b 62 2e 69 61 |axk)*409|6.0+b.ia|
|000038b0| 72 72 61 79 28 6d 61 78 | 6b 2d 31 29 29 29 20 27 |rray(max|k-1))) '|
|000038c0| 20 67 75 65 73 73 07 65 | 6e 64 20 69 66 20 04 65 | guess.e|nd if .e|
|000038d0| 6c 73 65 3f 6d 3d 28 64 | 2e 69 61 72 72 61 79 28 |lse?m=(d|.iarray(|
|000038e0| 6d 61 78 69 2b 31 29 2a | 34 30 39 36 2b 64 2e 69 |maxi+1)*|4096+d.i|
|000038f0| 61 72 72 61 79 28 6d 61 | 78 69 29 29 5c 62 2e 69 |array(ma|xi))\b.i|
|00003900| 61 72 72 61 79 28 6d 61 | 78 6b 29 20 27 20 67 75 |array(ma|xk) ' gu|
|00003910| 65 73 73 06 65 6e 64 20 | 69 66 04 77 65 6e 64 8b |ess.end |if.wend.|
|00003920| 01 69 66 20 28 6e 65 67 | 61 74 69 76 65 20 61 6e |.if (neg|ative an|
|00003930| 64 20 62 2e 6e 65 67 61 | 74 69 76 65 29 20 6f 72 |d b.nega|tive) or|
|00003940| 20 28 28 6e 6f 74 20 6e | 65 67 61 74 69 76 65 29 | ((not n|egative)|
|00003950| 20 61 6e 64 20 28 6e 6f | 74 20 62 2e 6e 65 67 61 | and (no|t b.nega|
|00003960| 74 69 76 65 29 29 20 74 | 68 65 6e 20 0e 6e 65 67 |tive)) t|hen .neg|
|00003970| 61 74 69 76 65 3d 66 61 | 6c 73 65 05 65 6c 73 65 |ative=fa|lse.else|
|00003980| 20 0d 6e 65 67 61 74 69 | 76 65 3d 74 72 75 65 06 | .negati|ve=true.|
|00003990| 65 6e 64 20 69 66 07 45 | 6e 64 20 53 75 62 04 7a |end if.E|nd Sub.z|
|000039a0| 65 72 6f 00 00 00 05 0e | 05 0e 07 0a 53 75 62 20 |ero.....|....Sub |
|000039b0| 7a 65 72 6f 28 29 10 44 | 69 6d 20 69 20 61 73 20 |zero().D|im i as |
|000039c0| 69 6e 74 65 67 65 72 14 | 66 6f 72 20 69 3d 31 20 |integer.|for i=1 |
|000039d0| 74 6f 20 70 72 65 63 69 | 73 69 6f 6e 0b 69 61 72 |to preci|sion.iar|
|000039e0| 72 61 79 28 69 29 3d 30 | 04 6e 65 78 74 0e 6e 65 |ray(i)=0|.next.ne|
|000039f0| 67 61 74 69 76 65 3d 66 | 61 6c 73 65 07 45 6e 64 |gative=f|alse.End|
|00003a00| 20 53 75 62 0c 53 74 72 | 69 6e 67 74 6f 6c 69 6e | Sub.Str|ingtolin|
|00003a10| 74 0b 73 20 61 73 20 73 | 74 72 69 6e 67 00 00 01 |t.s as s|tring...|
|00003a20| 1e 01 1e 24 1d 53 75 62 | 20 53 74 72 69 6e 67 74 |...$.Sub| Stringt|
|00003a30| 6f 6c 69 6e 74 28 73 20 | 61 73 20 73 74 72 69 6e |olint(s |as strin|
|00003a40| 67 29 8c 01 52 45 4d 20 | 70 72 6f 64 75 63 65 20 |g)..REM |produce |
|00003a50| 61 20 6e 75 6d 62 65 72 | 20 66 72 6f 6d 20 74 68 |a number| from th|
|00003a60| 65 20 73 74 72 69 6e 67 | 20 72 65 70 72 65 73 65 |e string| represe|
|00003a70| 6e 74 69 6e 67 20 74 68 | 65 20 6e 75 6d 62 65 72 |nting th|e number|
|00003a80| 20 69 6e 20 68 65 78 20 | 6e 6f 74 61 74 69 6f 6e | in hex |notation|
|00003a90| 12 44 69 6d 20 69 2c 6c | 20 61 73 20 69 6e 74 65 |.Dim i,l| as inte|
|00003aa0| 67 65 72 13 64 69 6d 20 | 70 2c 20 73 63 20 61 73 |ger.dim |p, sc as|
|00003ab0| 20 73 74 72 69 6e 67 14 | 69 66 20 70 72 65 63 69 | string.|if preci|
|00003ac0| 73 69 6f 6e 3d 30 20 74 | 68 65 6e 20 0e 70 72 65 |sion=0 t|hen .pre|
|00003ad0| 63 69 73 69 6f 6e 3d 31 | 30 32 34 06 65 6e 64 20 |cision=1|024.end |
|00003ae0| 69 66 16 69 66 20 70 72 | 65 63 69 73 69 6f 6e 3e |if.if pr|ecision>|
|00003af0| 31 30 32 34 20 74 68 65 | 6e 2a 4d 73 67 42 6f 78 |1024 the|n*MsgBox|
|00003b00| 20 22 50 72 65 63 69 73 | 69 6f 6e 20 74 6f 6f 20 | "Precis|ion too |
|00003b10| 68 69 67 68 20 69 6e 20 | 53 74 72 69 6e 67 74 6f |high in |Stringto|
|00003b20| 49 6e 74 22 06 72 65 74 | 75 72 6e 06 65 6e 64 20 |Int".ret|urn.end |
|00003b30| 69 66 08 6c 3d 6c 65 6e | 28 73 29 04 73 63 3d 73 |if.l=len|(s).sc=s|
|00003b40| 0c 69 66 20 6c 3d 30 20 | 74 68 65 6e 20 04 7a 65 |.if l=0 |then .ze|
|00003b50| 72 6f 06 72 65 74 75 72 | 6e 06 65 6e 64 20 69 66 |ro.retur|n.end if|
|00003b60| 0d 6c 3d 63 65 69 6c 28 | 6c 2f 33 2e 30 29 14 69 |.l=ceil(|l/3.0).i|
|00003b70| 66 20 6c 3e 70 72 65 63 | 69 73 69 6f 6e 20 74 68 |f l>prec|ision th|
|00003b80| 65 6e 20 0b 6c 3d 70 72 | 65 63 69 73 69 6f 6e 2e |en .l=pr|ecision.|
|00003b90| 4d 73 67 42 6f 78 20 22 | 43 6f 6e 76 65 72 73 69 |MsgBox "|Conversi|
|00003ba0| 6f 6e 20 73 74 72 69 6e | 67 2d 74 6f 2d 69 6e 74 |on strin|g-to-int|
|00003bb0| 65 67 65 72 20 6f 76 65 | 72 66 6c 6f 77 22 06 65 |eger ove|rflow".e|
|00003bc0| 6e 64 20 69 66 0c 66 6f | 72 20 69 3d 31 20 74 6f |nd if.fo|r i=1 to|
|00003bd0| 20 6c 10 27 4d 73 67 42 | 6f 78 20 22 73 63 3d 22 | l.'MsgB|ox "sc="|
|00003be0| 2b 73 63 0d 70 3d 72 69 | 67 68 74 28 73 63 2c 33 |+sc.p=ri|ght(sc,3|
|00003bf0| 29 0e 27 4d 73 67 42 6f | 78 20 22 70 3d 22 2b 70 |).'MsgBo|x "p="+p|
|00003c00| 16 73 63 3d 6c 65 66 74 | 28 73 63 2c 20 6c 65 6e |.sc=left|(sc, len|
|00003c10| 28 73 63 29 2d 33 29 15 | 69 61 72 72 61 79 28 69 |(sc)-3).|iarray(i|
|00003c20| 29 3d 56 61 6c 28 22 26 | 48 22 2b 70 29 14 27 69 |)=Val("&|H"+p).'i|
|00003c30| 66 20 69 61 72 72 61 79 | 28 69 29 3e 30 20 74 68 |f iarray|(i)>0 th|
|00003c40| 65 6e 23 27 4d 73 67 42 | 6f 78 20 22 69 61 72 72 |en#'MsgB|ox "iarr|
|00003c50| 61 79 28 69 29 3d 22 2b | 53 74 72 28 69 61 72 72 |ay(i)="+|Str(iarr|
|00003c60| 61 79 28 69 29 29 07 27 | 65 6e 64 20 69 66 04 6e |ay(i)).'|end if.n|
|00003c70| 65 78 74 16 66 6f 72 20 | 69 3d 6c 2b 31 20 74 6f |ext.for |i=l+1 to|
|00003c80| 20 70 72 65 63 69 73 69 | 6f 6e 0b 69 61 72 72 61 | precisi|on.iarra|
|00003c90| 79 28 69 29 3d 30 04 6e | 65 78 74 07 45 6e 64 20 |y(i)=0.n|ext.End |
|00003ca0| 53 75 62 03 41 64 64 0d | 62 20 61 73 20 4c 69 6e |Sub.Add.|b as Lin|
|00003cb0| 74 65 67 65 72 00 00 01 | 00 01 00 20 16 53 75 62 |teger...|... .Sub|
|00003cc0| 20 41 64 64 28 62 20 61 | 73 20 4c 69 6e 74 65 67 | Add(b a|s Linteg|
|00003cd0| 65 72 29 33 52 45 4d 20 | 41 64 64 20 74 77 6f 20 |er)3REM |Add two |
|00003ce0| 6c 6f 6e 67 20 69 6e 74 | 65 67 65 72 73 2c 20 74 |long int|egers, t|
|00003cf0| 61 6b 69 6e 67 20 73 69 | 67 6e 20 69 6e 74 6f 20 |aking si|gn into |
|00003d00| 61 63 63 6f 75 6e 74 36 | 52 45 4d 20 49 66 20 6e |account6|REM If n|
|00003d10| 65 63 65 73 73 61 72 79 | 2c 20 63 61 6c 6c 20 73 |ecessary|, call s|
|00003d20| 75 62 74 72 61 63 74 20 | 69 6e 73 74 65 61 64 20 |ubtract |instead |
|00003d30| 28 64 75 65 20 74 6f 20 | 73 69 67 6e 73 29 17 44 |(due to |signs).D|
|00003d40| 69 6d 20 69 2c 20 63 61 | 72 72 79 20 61 73 20 69 |im i, ca|rry as i|
|00003d50| 6e 74 65 67 65 72 8b 01 | 69 66 20 28 6e 65 67 61 |nteger..|if (nega|
|00003d60| 74 69 76 65 20 61 6e 64 | 20 62 2e 6e 65 67 61 74 |tive and| b.negat|
|00003d70| 69 76 65 29 20 6f 72 20 | 28 28 6e 6f 74 20 6e 65 |ive) or |((not ne|
|00003d80| 67 61 74 69 76 65 29 20 | 61 6e 64 20 28 6e 6f 74 |gative) |and (not|
|00003d90| 20 62 2e 6e 65 67 61 74 | 69 76 65 29 29 20 74 68 | b.negat|ive)) th|
|00003da0| 65 6e 20 15 52 45 4d 20 | 53 61 6d 65 20 73 69 67 |en .REM |Same sig|
|00003db0| 6e 2c 20 73 6f 20 61 64 | 64 07 63 61 72 72 79 3d |n, so ad|d.carry=|
|00003dc0| 30 14 66 6f 72 20 69 3d | 31 20 74 6f 20 70 72 65 |0.for i=|1 to pre|
|00003dd0| 63 69 73 69 6f 6e 25 69 | 61 72 72 61 79 28 69 29 |cision%i|array(i)|
|00003de0| 3d 69 61 72 72 61 79 28 | 69 29 2b 62 2e 69 61 72 |=iarray(|i)+b.iar|
|00003df0| 72 61 79 28 69 29 2b 63 | 61 72 72 79 17 69 66 20 |ray(i)+c|arry.if |
|00003e00| 69 61 72 72 61 79 28 69 | 29 3e 3d 34 30 39 36 20 |iarray(i|)>=4096 |
|00003e10| 74 68 65 6e 07 63 61 72 | 72 79 3d 31 18 69 61 72 |then.car|ry=1.iar|
|00003e20| 72 61 79 28 69 29 3d 69 | 61 72 72 61 79 28 69 29 |ray(i)=i|array(i)|
|00003e30| 2d 34 30 39 36 04 65 6c | 73 65 07 63 61 72 72 79 |-4096.el|se.carry|
|00003e40| 3d 30 06 65 6e 64 20 69 | 66 04 6e 65 78 74 10 69 |=0.end i|f.next.i|
|00003e50| 66 20 63 61 72 72 79 3e | 30 20 74 68 65 6e 20 1a |f carry>|0 then .|
|00003e60| 4d 73 67 42 6f 78 20 22 | 61 64 64 69 74 69 6f 6e |MsgBox "|addition|
|00003e70| 20 6f 76 65 72 66 6c 6f | 77 22 06 65 6e 64 20 69 | overflo|w".end i|
|00003e80| 66 06 72 65 74 75 72 6e | 06 65 6e 64 20 69 66 8b |f.return|.end if.|
|00003e90| 01 69 66 20 28 6e 65 67 | 61 74 69 76 65 20 61 6e |.if (neg|ative an|
|00003ea0| 64 20 28 6e 6f 74 20 62 | 2e 6e 65 67 61 74 69 76 |d (not b|.negativ|
|00003eb0| 65 29 29 20 6f 72 20 20 | 28 28 6e 6f 74 20 6e 65 |e)) or |((not ne|
|00003ec0| 67 61 74 69 76 65 29 20 | 61 6e 64 20 62 2e 6e 65 |gative) |and b.ne|
|00003ed0| 67 61 74 69 76 65 29 20 | 74 68 65 6e 21 52 45 4d |gative) |then!REM|
|00003ee0| 20 64 69 66 66 65 72 65 | 6e 74 20 73 69 67 6e 73 | differe|nt signs|
|00003ef0| 2c 20 73 6f 20 73 75 62 | 74 72 61 63 74 2e 82 01 |, so sub|tract...|
|00003f00| 52 45 4d 20 68 6f 77 65 | 76 65 72 2c 20 63 68 61 |REM howe|ver, cha|
|00003f10| 6e 67 65 20 74 68 65 20 | 73 69 67 6e 20 6f 66 20 |nge the |sign of |
|00003f20| 6f 6e 65 20 74 65 6d 70 | 6f 72 61 72 69 6c 79 20 |one temp|orarily |
|00003f30| 74 6f 20 61 76 6f 69 64 | 20 70 69 6e 67 2d 70 6f |to avoid| ping-po|
|00003f40| 6e 67 1c 52 45 4d 20 62 | 65 74 77 65 65 6e 20 61 |ng.REM b|etween a|
|00003f50| 64 64 20 61 6e 64 20 73 | 75 62 74 72 61 63 74 15 |dd and s|ubtract.|
|00003f60| 6e 65 67 61 74 69 76 65 | 3d 6e 6f 74 20 6e 65 67 |negative|=not neg|
|00003f70| 61 74 69 76 65 0a 53 75 | 62 74 72 61 63 74 20 62 |ative.Su|btract b|
|00003f80| 15 6e 65 67 61 74 69 76 | 65 3d 6e 6f 74 20 6e 65 |.negativ|e=not ne|
|00003f90| 67 61 74 69 76 65 06 72 | 65 74 75 72 6e 06 65 6e |gative.r|eturn.en|
|00003fa0| 64 20 69 66 00 07 45 6e | 64 20 53 75 62 0c 4c 69 |d if..En|d Sub.Li|
|00003fb0| 6e 74 74 6f 53 74 72 69 | 6e 67 00 06 53 74 72 69 |nttoStri|ng..Stri|
|00003fc0| 6e 67 00 01 00 02 00 1b | 21 46 75 6e 63 74 69 6f |ng......|!Functio|
|00003fd0| 6e 20 4c 69 6e 74 74 6f | 53 74 72 69 6e 67 28 29 |n Lintto|String()|
|00003fe0| 20 41 73 20 53 74 72 69 | 6e 67 3c 52 45 4d 20 70 | As Stri|ng<REM p|
|00003ff0| 72 6f 64 75 63 65 20 61 | 20 73 74 72 69 6e 67 20 |roduce a| string |
|00004000| 72 65 70 72 65 73 65 6e | 74 69 6e 67 20 74 68 65 |represen|ting the|
|00004010| 20 6e 75 6d 62 65 72 20 | 69 6e 20 68 65 78 20 6e | number |in hex n|
|00004020| 6f 74 61 74 69 6f 6e 12 | 44 69 6d 20 69 2c 6b 20 |otation.|Dim i,k |
|00004030| 61 73 20 69 6e 74 65 67 | 65 72 12 64 69 6d 20 70 |as integ|er.dim p|
|00004040| 2c 20 73 20 61 73 20 73 | 74 72 69 6e 67 04 73 3d |, s as s|tring.s=|
|00004050| 22 22 18 52 45 4d 20 46 | 69 6e 64 20 6c 61 73 74 |"".REM F|ind last|
|00004060| 20 6e 75 6d 62 65 72 20 | 3c 3e 30 06 6b 3d 31 30 | number |<>0.k=10|
|00004070| 32 34 19 77 68 69 6c 65 | 20 69 61 72 72 61 79 28 |24.while| iarray(|
|00004080| 6b 29 3d 30 20 61 6e 64 | 20 6b 3e 31 05 6b 3d 6b |k)=0 and| k>1.k=k|
|00004090| 2d 31 04 77 65 6e 64 24 | 27 4d 73 67 42 6f 78 20 |-1.wend$|'MsgBox |
|000040a0| 22 6b 20 77 61 73 20 7a | 65 72 6f 20 64 6f 77 6e |"k was z|ero down|
|000040b0| 20 74 6f 20 22 2b 53 74 | 72 28 6b 29 0c 66 6f 72 | to "+St|r(k).for|
|000040c0| 20 69 3d 31 20 74 6f 20 | 6b 10 70 3d 48 65 78 28 | i=1 to |k.p=Hex(|
|000040d0| 69 61 72 72 61 79 28 69 | 29 29 14 27 69 66 20 69 |iarray(i|)).'if i|
|000040e0| 61 72 72 61 79 28 69 29 | 3e 30 20 74 68 65 6e 12 |array(i)|>0 then.|
|000040f0| 27 4d 73 67 42 6f 78 20 | 22 48 65 78 20 70 3d 22 |'MsgBox |"Hex p="|
|00004100| 2b 70 07 27 65 6e 64 20 | 69 66 0e 77 68 69 6c 65 |+p.'end |if.while|
|00004110| 20 6c 65 6e 28 70 29 3c | 33 07 70 3d 22 30 22 2b | len(p)<|3.p="0"+|
|00004120| 70 04 77 65 6e 64 05 73 | 3d 70 2b 73 04 6e 65 78 |p.wend.s|=p+s.nex|
|00004130| 74 23 27 4d 73 67 42 6f | 78 20 22 72 65 73 75 6c |t#'MsgBo|x "resul|
|00004140| 74 20 6f 66 20 4c 69 6e | 74 74 6f 53 74 72 69 6e |t of Lin|ttoStrin|
|00004150| 67 3d 22 2b 73 11 69 66 | 20 6e 65 67 61 74 69 76 |g="+s.if| negativ|
|00004160| 65 20 74 68 65 6e 20 07 | 73 3d 22 2d 22 2b 73 06 |e then .|s="-"+s.|
|00004170| 65 6e 64 20 69 66 08 72 | 65 74 75 72 6e 20 73 0c |end if.r|eturn s.|
|00004180| 45 6e 64 20 46 75 6e 63 | 74 69 6f 6e 06 49 6e 74 |End Func|tion.Int|
|00004190| 4d 69 6e 1a 78 20 61 73 | 20 69 6e 74 65 67 65 72 |Min.x as| integer|
|000041a0| 2c 20 79 20 61 73 20 69 | 6e 74 65 67 65 72 07 49 |, y as i|nteger.I|
|000041b0| 6e 74 65 67 65 72 00 01 | 21 01 21 08 36 46 75 6e |nteger..|!.!.6Fun|
|000041c0| 63 74 69 6f 6e 20 49 6e | 74 4d 69 6e 28 78 20 61 |ction In|tMin(x a|
|000041d0| 73 20 69 6e 74 65 67 65 | 72 2c 20 79 20 61 73 20 |s intege|r, y as |
|000041e0| 69 6e 74 65 67 65 72 29 | 20 41 73 20 49 6e 74 65 |integer)| As Inte|
|000041f0| 67 65 72 21 52 45 4d 20 | 72 65 74 75 72 6e 20 74 |ger!REM |return t|
|00004200| 68 65 20 73 6d 61 6c 6c | 65 73 74 20 6f 66 20 78 |he small|est of x|
|00004210| 20 6f 72 20 79 0b 69 66 | 20 78 3c 79 20 74 68 65 | or y.if| x<y the|
|00004220| 6e 08 72 65 74 75 72 6e | 20 78 04 65 6c 73 65 08 |n.return| x.else.|
|00004230| 72 65 74 75 72 6e 20 79 | 06 65 6e 64 20 69 66 0c |return y|.end if.|
|00004240| 45 6e 64 20 46 75 6e 63 | 74 69 6f 6e 08 53 75 62 |End Func|tion.Sub|
|00004250| 74 72 61 63 74 0d 62 20 | 61 73 20 4c 69 6e 74 65 |tract.b |as Linte|
|00004260| 67 65 72 00 00 01 13 01 | 13 2a 1b 53 75 62 20 53 |ger.....|.*.Sub S|
|00004270| 75 62 74 72 61 63 74 28 | 62 20 61 73 20 4c 69 6e |ubtract(|b as Lin|
|00004280| 74 65 67 65 72 29 13 52 | 45 4d 20 63 61 6c 63 75 |teger).R|EM calcu|
|00004290| 6c 61 74 65 20 61 3d 61 | 2d 62 17 44 69 6d 20 69 |late a=a|-b.Dim i|
|000042a0| 2c 20 63 61 72 72 79 20 | 61 73 20 69 6e 74 65 67 |, carry |as integ|
|000042b0| 65 72 8b 01 69 66 20 28 | 6e 65 67 61 74 69 76 65 |er..if (|negative|
|000042c0| 20 61 6e 64 20 28 6e 6f | 74 20 62 2e 6e 65 67 61 | and (no|t b.nega|
|000042d0| 74 69 76 65 29 29 20 6f | 72 20 20 28 28 6e 6f 74 |tive)) o|r ((not|
|000042e0| 20 6e 65 67 61 74 69 76 | 65 29 20 61 6e 64 20 62 | negativ|e) and b|
|000042f0| 2e 6e 65 67 61 74 69 76 | 65 29 20 74 68 65 6e 15 |.negativ|e) then.|
|00004300| 6e 65 67 61 74 69 76 65 | 3d 6e 6f 74 20 6e 65 67 |negative|=not neg|
|00004310| 61 74 69 76 65 05 41 64 | 64 20 62 15 6e 65 67 61 |ative.Ad|d b.nega|
|00004320| 74 69 76 65 3d 6e 6f 74 | 20 6e 65 67 61 74 69 76 |tive=not| negativ|
|00004330| 65 06 72 65 74 75 72 6e | 06 65 6e 64 20 69 66 8b |e.return|.end if.|
|00004340| 01 69 66 20 28 6e 65 67 | 61 74 69 76 65 20 61 6e |.if (neg|ative an|
|00004350| 64 20 62 2e 6e 65 67 61 | 74 69 76 65 29 20 6f 72 |d b.nega|tive) or|
|00004360| 20 28 28 6e 6f 74 20 6e | 65 67 61 74 69 76 65 29 | ((not n|egative)|
|00004370| 20 61 6e 64 20 28 6e 6f | 74 20 62 2e 6e 65 67 61 | and (no|t b.nega|
|00004380| 74 69 76 65 29 29 20 74 | 68 65 6e 20 07 63 61 72 |tive)) t|hen .car|
|00004390| 72 79 3d 30 14 66 6f 72 | 20 69 3d 31 20 74 6f 20 |ry=0.for| i=1 to |
|000043a0| 70 72 65 63 69 73 69 6f | 6e 3a 27 4d 73 67 42 6f |precisio|n:'MsgBo|
|000043b0| 78 20 53 74 72 28 69 61 | 72 72 61 79 28 69 29 29 |x Str(ia|rray(i))|
|000043c0| 2b 22 2c 22 2b 53 74 72 | 28 62 2e 69 61 72 72 61 |+","+Str|(b.iarra|
|000043d0| 79 28 69 29 29 2b 22 2c | 22 2b 53 74 72 28 63 61 |y(i))+",|"+Str(ca|
|000043e0| 72 72 79 29 25 69 61 72 | 72 61 79 28 69 29 3d 69 |rry)%iar|ray(i)=i|
|000043f0| 61 72 72 61 79 28 69 29 | 2d 62 2e 69 61 72 72 61 |array(i)|-b.iarra|
|00004400| 79 28 69 29 2d 63 61 72 | 72 79 14 69 66 20 20 69 |y(i)-car|ry.if i|
|00004410| 61 72 72 61 79 28 69 29 | 3c 30 20 74 68 65 6e 07 |array(i)|<0 then.|
|00004420| 63 61 72 72 79 3d 31 18 | 69 61 72 72 61 79 28 69 |carry=1.|iarray(i|
|00004430| 29 3d 69 61 72 72 61 79 | 28 69 29 2b 34 30 39 36 |)=iarray|(i)+4096|
|00004440| 05 65 6c 73 65 20 07 63 | 61 72 72 79 3d 30 06 65 |.else .c|arry=0.e|
|00004450| 6e 64 20 69 66 15 27 63 | 61 72 72 79 3d 69 61 72 |nd if.'c|arry=iar|
|00004460| 72 61 79 28 69 29 5c 34 | 30 39 36 1d 27 69 61 72 |ray(i)\4|096.'iar|
|00004470| 72 61 79 28 69 29 3d 69 | 61 72 72 61 79 28 69 29 |ray(i)=i|array(i)|
|00004480| 20 6d 6f 64 20 34 30 39 | 36 14 27 69 66 20 69 61 | mod 409|6.'if ia|
|00004490| 72 72 61 79 28 69 29 3e | 30 20 74 68 65 6e 23 27 |rray(i)>|0 then#'|
|000044a0| 4d 73 67 42 6f 78 20 22 | 69 61 72 72 61 79 28 69 |MsgBox "|iarray(i|
|000044b0| 29 3d 22 2b 53 74 72 28 | 69 61 72 72 61 79 28 69 |)="+Str(|iarray(i|
|000044c0| 29 29 07 27 65 6e 64 20 | 69 66 04 6e 65 78 74 10 |)).'end |if.next.|
|000044d0| 69 66 20 63 61 72 72 79 | 3e 30 20 74 68 65 6e 20 |if carry|>0 then |
|000044e0| 15 6e 65 67 61 74 69 76 | 65 3d 6e 6f 74 20 6e 65 |.negativ|e=not ne|
|000044f0| 67 61 74 69 76 65 07 63 | 61 72 72 79 3d 30 14 66 |gative.c|arry=0.f|
|00004500| 6f 72 20 69 3d 31 20 74 | 6f 20 70 72 65 63 69 73 |or i=1 t|o precis|
|00004510| 69 6f 6e 3a 27 4d 73 67 | 42 6f 78 20 53 74 72 28 |ion:'Msg|Box Str(|
|00004520| 69 61 72 72 61 79 28 69 | 29 29 2b 22 2c 22 2b 53 |iarray(i|))+","+S|
|00004530| 74 72 28 62 2e 69 61 72 | 72 61 79 28 69 29 29 2b |tr(b.iar|ray(i))+|
|00004540| 22 2c 22 2b 53 74 72 28 | 63 61 72 72 79 29 1a 69 |","+Str(|carry).i|
|00004550| 61 72 72 61 79 28 69 29 | 3d 2d 69 61 72 72 61 79 |array(i)|=-iarray|
|00004560| 28 69 29 2d 63 61 72 72 | 79 14 69 66 20 20 69 61 |(i)-carr|y.if ia|
|00004570| 72 72 61 79 28 69 29 3c | 30 20 74 68 65 6e 07 63 |rray(i)<|0 then.c|
|00004580| 61 72 72 79 3d 31 18 69 | 61 72 72 61 79 28 69 29 |arry=1.i|array(i)|
|00004590| 3d 69 61 72 72 61 79 28 | 69 29 2b 34 30 39 36 05 |=iarray(|i)+4096.|
|000045a0| 65 6c 73 65 20 07 63 61 | 72 72 79 3d 30 06 65 6e |else .ca|rry=0.en|
|000045b0| 64 20 69 66 04 6e 65 78 | 74 06 65 6e 64 20 69 66 |d if.nex|t.end if|
|000045c0| 06 65 6e 64 20 69 66 07 | 45 6e 64 20 53 75 62 07 |.end if.|End Sub.|
|000045d0| 47 72 65 61 74 65 72 0d | 62 20 61 73 20 4c 69 6e |Greater.|b as Lin|
|000045e0| 74 65 67 65 72 07 42 6f | 6f 6c 65 61 6e 00 01 16 |teger.Bo|olean...|
|000045f0| 01 16 0e 2a 46 75 6e 63 | 74 69 6f 6e 20 47 72 65 |...*Func|tion Gre|
|00004600| 61 74 65 72 28 62 20 61 | 73 20 4c 69 6e 74 65 67 |ater(b a|s Linteg|
|00004610| 65 72 29 20 41 73 20 42 | 6f 6f 6c 65 61 6e 17 52 |er) As B|oolean.R|
|00004620| 45 4d 20 72 65 74 75 72 | 6e 20 74 72 75 65 20 69 |EM retur|n true i|
|00004630| 66 20 61 3e 3d 62 10 44 | 69 6d 20 69 20 61 73 20 |f a>=b.D|im i as |
|00004640| 69 6e 74 65 67 65 72 24 | 52 45 4d 20 64 6f 65 73 |integer$|REM does|
|00004650| 20 6e 6f 74 20 74 61 6b | 65 20 73 69 67 6e 73 20 | not tak|e signs |
|00004660| 69 6e 74 6f 20 61 63 63 | 6f 75 6e 74 19 46 6f 72 |into acc|ount.For|
|00004670| 20 69 3d 20 70 72 65 63 | 69 73 69 6f 6e 20 64 6f | i= prec|ision do|
|00004680| 77 6e 74 6f 20 31 1d 49 | 66 20 69 61 72 72 61 79 |wnto 1.I|f iarray|
|00004690| 28 69 29 3e 62 2e 69 61 | 72 72 61 79 28 69 29 20 |(i)>b.ia|rray(i) |
|000046a0| 74 68 65 6e 0b 72 65 74 | 75 72 6e 20 74 72 75 65 |then.ret|urn true|
|000046b0| 06 65 6e 64 20 69 66 1d | 49 66 20 69 61 72 72 61 |.end if.|If iarra|
|000046c0| 79 28 69 29 3c 62 2e 69 | 61 72 72 61 79 28 69 29 |y(i)<b.i|array(i)|
|000046d0| 20 74 68 65 6e 0c 72 65 | 74 75 72 6e 20 66 61 6c | then.re|turn fal|
|000046e0| 73 65 06 65 6e 64 20 69 | 66 04 6e 65 78 74 1b 72 |se.end i|f.next.r|
|000046f0| 65 74 75 72 6e 20 74 72 | 75 65 20 27 54 68 65 79 |eturn tr|ue 'They|
|00004700| 20 61 72 65 20 65 71 75 | 61 6c 0c 45 6e 64 20 46 | are equ|al.End F|
|00004710| 75 6e 63 74 69 6f 6e 06 | 53 68 69 66 74 4c 11 70 |unction.|ShiftL.p|
|00004720| 6c 61 63 65 73 20 61 73 | 20 69 6e 74 65 67 65 72 |laces as| integer|
|00004730| 00 00 01 00 03 00 0e 1d | 53 75 62 20 53 68 69 66 |........|Sub Shif|
|00004740| 74 4c 28 70 6c 61 63 65 | 73 20 61 73 20 69 6e 74 |tL(place|s as int|
|00004750| 65 67 65 72 29 13 52 45 | 4d 20 61 3d 61 2a 34 30 |eger).RE|M a=a*40|
|00004760| 39 36 5e 70 6c 61 63 65 | 73 28 52 45 4d 20 73 68 |96^place|s(REM sh|
|00004770| 69 66 74 73 20 74 68 65 | 20 64 69 67 69 74 73 20 |ifts the| digits |
|00004780| 6f 66 20 22 61 22 20 74 | 6f 20 74 68 65 20 6c 65 |of "a" t|o the le|
|00004790| 66 74 10 44 69 6d 20 69 | 20 61 73 20 69 6e 74 65 |ft.Dim i| as inte|
|000047a0| 67 65 72 12 69 66 20 70 | 6c 61 63 65 73 20 3c 3d |ger.if p|laces <=|
|000047b0| 30 20 74 68 65 6e 06 72 | 65 74 75 72 6e 06 65 6e |0 then.r|eturn.en|
|000047c0| 64 20 69 66 1f 46 6f 72 | 20 69 3d 70 72 65 63 69 |d if.For| i=preci|
|000047d0| 73 69 6f 6e 20 64 6f 77 | 6e 74 6f 20 70 6c 61 63 |sion dow|nto plac|
|000047e0| 65 73 2b 31 1a 69 61 72 | 72 61 79 28 69 29 3d 69 |es+1.iar|ray(i)=i|
|000047f0| 61 72 72 61 79 28 69 2d | 70 6c 61 63 65 73 29 04 |array(i-|places).|
|00004800| 6e 65 78 74 15 46 6f 72 | 20 69 3d 70 6c 61 63 65 |next.For| i=place|
|00004810| 73 20 64 6f 77 6e 74 6f | 20 31 0b 69 61 72 72 61 |s downto| 1.iarra|
|00004820| 79 28 69 29 3d 30 04 6e | 65 78 74 07 45 6e 64 20 |y(i)=0.n|ext.End |
|00004830| 53 75 62 06 53 68 69 66 | 74 52 11 70 6c 61 63 65 |Sub.Shif|tR.place|
|00004840| 73 20 61 73 20 69 6e 74 | 65 67 65 72 00 00 02 29 |s as int|eger...)|
|00004850| 02 29 0e 1d 53 75 62 20 | 53 68 69 66 74 52 28 70 |.)..Sub |ShiftR(p|
|00004860| 6c 61 63 65 73 20 61 73 | 20 69 6e 74 65 67 65 72 |laces as| integer|
|00004870| 29 13 52 45 4d 20 61 3d | 61 2f 34 30 39 36 5e 70 |).REM a=|a/4096^p|
|00004880| 6c 61 63 65 73 29 52 45 | 4d 20 73 68 69 66 74 73 |laces)RE|M shifts|
|00004890| 20 74 68 65 20 64 69 67 | 69 74 73 20 6f 66 20 22 | the dig|its of "|
|000048a0| 61 22 20 74 6f 20 74 68 | 65 20 72 69 67 68 74 10 |a" to th|e right.|
|000048b0| 44 69 6d 20 69 20 61 73 | 20 69 6e 74 65 67 65 72 |Dim i as| integer|
|000048c0| 12 69 66 20 70 6c 61 63 | 65 73 20 3c 3d 30 20 74 |.if plac|es <=0 t|
|000048d0| 68 65 6e 06 72 65 74 75 | 72 6e 06 65 6e 64 20 69 |hen.retu|rn.end i|
|000048e0| 66 1b 46 6f 72 20 69 3d | 31 20 74 6f 20 70 72 65 |f.For i=|1 to pre|
|000048f0| 63 69 73 69 6f 6e 2d 70 | 6c 61 63 65 73 1a 69 61 |cision-p|laces.ia|
|00004900| 72 72 61 79 28 69 29 3d | 69 61 72 72 61 79 28 69 |rray(i)=|iarray(i|
|00004910| 2b 70 6c 61 63 65 73 29 | 04 6e 65 78 74 25 46 6f |+places)|.next%Fo|
|00004920| 72 20 69 3d 70 72 65 63 | 69 73 69 6f 6e 2d 70 6c |r i=prec|ision-pl|
|00004930| 61 63 65 73 2b 31 20 74 | 6f 20 70 72 65 63 69 73 |aces+1 t|o precis|
|00004940| 69 6f 6e 0b 69 61 72 72 | 61 79 28 69 29 3d 30 04 |ion.iarr|ay(i)=0.|
|00004950| 6e 65 78 74 07 45 6e 64 | 20 53 75 62 09 49 6d 75 |next.End| Sub.Imu|
|00004960| 6c 74 69 70 6c 79 0c 70 | 20 61 73 20 69 6e 74 65 |ltiply.p| as inte|
|00004970| 67 65 72 00 00 02 27 02 | 27 0f 1b 53 75 62 20 49 |ger...'.|'..Sub I|
|00004980| 6d 75 6c 74 69 70 6c 79 | 28 70 20 61 73 20 69 6e |multiply|(p as in|
|00004990| 74 65 67 65 72 29 14 52 | 45 4d 20 63 61 6c 63 75 |teger).R|EM calcu|
|000049a0| 6c 61 74 65 20 61 3d 61 | 2a 70 20 27 52 45 4d 20 |late a=a|*p 'REM |
|000049b0| 77 68 65 72 65 20 70 20 | 69 73 20 61 20 73 6d 61 |where p |is a sma|
|000049c0| 6c 6c 20 70 6f 73 69 74 | 69 76 65 20 69 6e 74 65 |ll posit|ive inte|
|000049d0| 67 65 72 10 44 69 6d 20 | 69 20 61 73 20 69 6e 74 |ger.Dim |i as int|
|000049e0| 65 67 65 72 15 44 69 6d | 20 63 61 72 72 79 20 20 |eger.Dim| carry |
|000049f0| 61 73 20 69 6e 74 65 67 | 65 72 07 63 61 72 72 79 |as integ|er.carry|
|00004a00| 3d 30 14 46 6f 72 20 69 | 3d 31 20 74 6f 20 70 72 |=0.For i|=1 to pr|
|00004a10| 65 63 69 73 69 6f 6e 1b | 69 61 72 72 61 79 28 69 |ecision.|iarray(i|
|00004a20| 29 3d 69 61 72 72 61 79 | 28 69 29 2a 70 2b 63 61 |)=iarray|(i)*p+ca|
|00004a30| 72 72 79 15 63 61 72 72 | 79 3d 20 69 61 72 72 61 |rry.carr|y= iarra|
|00004a40| 79 28 69 29 5c 34 30 39 | 36 24 69 61 72 72 61 79 |y(i)\409|6$iarray|
|00004a50| 28 69 29 3d 42 69 74 77 | 69 73 65 41 6e 64 28 69 |(i)=Bitw|iseAnd(i|
|00004a60| 61 72 72 61 79 28 69 29 | 2c 34 30 39 35 29 04 6e |array(i)|,4095).n|
|00004a70| 65 78 74 0f 49 66 20 63 | 61 72 72 79 3e 30 20 74 |ext.If c|arry>0 t|
|00004a80| 68 65 6e 34 4d 73 67 42 | 6f 78 20 22 53 6d 61 6c |hen4MsgB|ox "Smal|
|00004a90| 6c 20 69 6e 74 65 67 65 | 72 20 4d 75 6c 74 69 70 |l intege|r Multip|
|00004aa0| 6c 69 63 61 74 69 6f 6e | 20 6f 76 65 72 66 6c 6f |lication| overflo|
|00004ab0| 77 20 65 72 72 6f 72 22 | 06 65 6e 64 20 69 66 07 |w error"|.end if.|
|00004ac0| 45 6e 64 20 53 75 62 06 | 6d 6f 64 75 6c 6f 0d 62 |End Sub.|modulo.b|
|00004ad0| 20 61 73 20 4c 69 6e 74 | 65 67 65 72 00 00 01 00 | as Lint|eger....|
|00004ae0| 02 00 19 19 53 75 62 20 | 6d 6f 64 75 6c 6f 28 62 |....Sub |modulo(b|
|00004af0| 20 61 73 20 4c 69 6e 74 | 65 67 65 72 29 1c 52 45 | as Lint|eger).RE|
|00004b00| 4d 20 63 61 6c 63 75 6c | 61 74 65 20 20 61 3d 61 |M calcul|ate a=a|
|00004b10| 20 6d 6f 64 75 6c 6f 20 | 62 20 11 44 69 6d 20 64 | modulo |b .Dim d|
|00004b20| 20 61 73 20 4c 69 6e 74 | 65 67 65 72 10 44 69 6d | as Lint|eger.Dim|
|00004b30| 20 69 20 61 73 20 69 6e | 74 65 67 65 72 16 44 69 | i as in|teger.Di|
|00004b40| 6d 20 6e 65 67 74 65 6d | 70 20 61 73 20 62 6f 6f |m negtem|p as boo|
|00004b50| 6c 65 61 6e 1e 52 45 4d | 20 69 66 20 61 3c 62 20 |lean.REM| if a<b |
|00004b60| 74 68 65 6e 20 61 20 6d | 6f 64 75 6c 6f 20 62 20 |then a m|odulo b |
|00004b70| 3d 20 61 16 69 66 20 6e | 6f 74 20 47 72 65 61 74 |= a.if n|ot Great|
|00004b80| 65 72 28 62 29 20 74 68 | 65 6e 06 72 65 74 75 72 |er(b) th|en.retur|
|00004b90| 6e 06 65 6e 64 20 69 66 | 10 6e 65 67 74 65 6d 70 |n.end if|.negtemp|
|00004ba0| 3d 6e 65 67 61 74 69 76 | 65 0e 6e 65 67 61 74 69 |=negativ|e.negati|
|00004bb0| 76 65 3d 66 61 6c 73 65 | 0f 64 3d 20 6e 65 77 20 |ve=false|.d= new |
|00004bc0| 4c 69 6e 74 65 67 65 72 | 14 46 6f 72 20 69 3d 31 |Linteger|.For i=1|
|00004bd0| 20 74 6f 20 70 72 65 63 | 69 73 69 6f 6e 15 64 2e | to prec|ision.d.|
|00004be0| 69 61 72 72 61 79 28 69 | 29 3d 69 61 72 72 61 79 |iarray(i|)=iarray|
|00004bf0| 28 69 29 04 6e 65 78 74 | 15 64 2e 70 72 65 63 69 |(i).next|.d.preci|
|00004c00| 73 69 6f 6e 3d 70 72 65 | 63 69 73 69 6f 6e 0a 64 |sion=pre|cision.d|
|00004c10| 2e 44 69 76 69 64 65 20 | 62 0c 64 2e 4d 75 6c 74 |.Divide |b.d.Mult|
|00004c20| 69 70 6c 79 20 62 0a 53 | 75 62 74 72 61 63 74 20 |iply b.S|ubtract |
|00004c30| 64 0f 69 66 20 6e 65 67 | 74 65 6d 70 20 74 68 65 |d.if neg|temp the|
|00004c40| 6e 18 4d 73 67 42 6f 78 | 20 22 6e 65 67 61 74 69 |n.MsgBox| "negati|
|00004c50| 76 65 20 6d 6f 64 75 6c | 6f 22 0a 53 75 62 74 72 |ve modul|o".Subtr|
|00004c60| 61 63 74 20 62 0e 6e 65 | 67 61 74 69 76 65 3d 66 |act b.ne|gative=f|
|00004c70| 61 6c 73 65 06 65 6e 64 | 20 69 66 07 45 6e 64 20 |alse.end| if.End |
|00004c80| 53 75 62 08 45 78 70 6f | 6e 65 6e 74 0d 62 20 61 |Sub.Expo|nent.b a|
|00004c90| 73 20 4c 69 6e 74 65 67 | 65 72 00 00 01 14 01 14 |s Linteg|er......|
|00004ca0| 2c 1b 53 75 62 20 45 78 | 70 6f 6e 65 6e 74 28 62 |,.Sub Ex|ponent(b|
|00004cb0| 20 61 73 20 4c 69 6e 74 | 65 67 65 72 29 14 52 45 | as Lint|eger).RE|
|00004cc0| 4d 20 63 61 6c 63 75 6c | 61 74 65 20 20 61 3d 61 |M calcul|ate a=a|
|00004cd0| 5e 62 15 52 45 4d 20 62 | 20 69 73 20 74 68 65 20 |^b.REM b| is the |
|00004ce0| 65 78 70 6f 6e 65 6e 74 | 11 44 69 6d 20 64 20 61 |exponent|.Dim d a|
|00004cf0| 73 20 4c 69 6e 74 65 67 | 65 72 11 44 69 6d 20 63 |s Linteg|er.Dim c|
|00004d00| 20 61 73 20 4c 69 6e 74 | 65 67 65 72 18 44 69 6d | as Lint|eger.Dim|
|00004d10| 20 69 2c 6b 2c 20 6d 61 | 78 65 20 61 73 20 69 6e | i,k, ma|xe as in|
|00004d20| 74 65 67 65 72 12 44 69 | 6d 20 62 69 74 20 61 73 |teger.Di|m bit as|
|00004d30| 20 69 6e 74 65 67 65 72 | 20 64 69 6d 20 70 32 20 | integer| dim p2 |
|00004d40| 61 73 20 69 6e 74 65 67 | 65 72 20 72 65 6d 20 70 |as integ|er rem p|
|00004d50| 6f 77 65 72 20 6f 66 20 | 32 12 69 66 20 62 2e 6e |ower of |2.if b.n|
|00004d60| 65 67 61 74 69 76 65 20 | 74 68 65 6e 2b 4d 73 67 |egative |then+Msg|
|00004d70| 42 6f 78 20 22 6e 65 67 | 61 74 69 76 65 20 65 78 |Box "neg|ative ex|
|00004d80| 70 6f 6e 65 6e 74 73 20 | 6e 6f 74 20 69 6d 70 6c |ponents |not impl|
|00004d90| 65 6d 65 6e 74 65 64 22 | 06 72 65 74 75 72 6e 06 |emented"|.return.|
|00004da0| 65 6e 64 20 69 66 10 69 | 66 20 6e 65 67 61 74 69 |end if.i|f negati|
|00004db0| 76 65 20 74 68 65 6e 1c | 69 66 20 62 2e 69 61 72 |ve then.|if b.iar|
|00004dc0| 72 61 79 28 31 29 20 6d | 6f 64 20 32 20 3d 30 20 |ray(1) m|od 2 =0 |
|00004dd0| 74 68 65 6e 0e 6e 65 67 | 61 74 69 76 65 3d 66 61 |then.neg|ative=fa|
|00004de0| 6c 73 65 06 65 6e 64 20 | 69 66 06 65 6e 64 20 69 |lse.end |if.end i|
|00004df0| 66 0f 64 3d 20 6e 65 77 | 20 4c 69 6e 74 65 67 65 |f.d= new| Lintege|
|00004e00| 72 15 64 2e 70 72 65 63 | 69 73 69 6f 6e 3d 70 72 |r.d.prec|ision=pr|
|00004e10| 65 63 69 73 69 6f 6e 06 | 64 2e 7a 65 72 6f 0d 64 |ecision.|d.zero.d|
|00004e20| 2e 69 61 72 72 61 79 28 | 31 29 3d 31 0f 63 3d 20 |.iarray(|1)=1.c= |
|00004e30| 6e 65 77 20 4c 69 6e 74 | 65 67 65 72 14 46 6f 72 |new Lint|eger.For|
|00004e40| 20 69 3d 31 20 74 6f 20 | 70 72 65 63 69 73 69 6f | i=1 to |precisio|
|00004e50| 6e 15 63 2e 69 61 72 72 | 61 79 28 69 29 3d 69 61 |n.c.iarr|ay(i)=ia|
|00004e60| 72 72 61 79 28 69 29 04 | 6e 65 78 74 15 63 2e 70 |rray(i).|next.c.p|
|00004e70| 72 65 63 69 73 69 6f 6e | 3d 70 72 65 63 69 73 69 |recision|=precisi|
|00004e80| 6f 6e 0e 6d 61 78 65 3d | 70 72 65 63 69 73 69 6f |on.maxe=|precisio|
|00004e90| 6e 21 77 68 69 6c 65 20 | 62 2e 69 61 72 72 61 79 |n!while |b.iarray|
|00004ea0| 28 6d 61 78 65 29 3d 30 | 20 61 6e 64 20 6d 61 78 |(maxe)=0| and max|
|00004eb0| 65 3e 30 0b 6d 61 78 65 | 3d 6d 61 78 65 2d 31 04 |e>0.maxe|=maxe-1.|
|00004ec0| 77 65 6e 64 0f 46 6f 72 | 20 69 3d 31 20 74 6f 20 |wend.For| i=1 to |
|00004ed0| 6d 61 78 65 04 70 32 3d | 31 0d 46 6f 72 20 6b 3d |maxe.p2=|1.For k=|
|00004ee0| 31 20 74 6f 20 31 32 1f | 62 69 74 3d 62 69 74 77 |1 to 12.|bit=bitw|
|00004ef0| 69 73 65 41 6e 64 28 62 | 2e 69 61 72 72 61 79 28 |iseAnd(b|.iarray(|
|00004f00| 69 29 2c 20 70 32 29 0d | 49 66 20 62 69 74 3e 30 |i), p2).|If bit>0|
|00004f10| 20 74 68 65 6e 0c 64 2e | 4d 75 6c 74 69 70 6c 79 | then.d.|Multiply|
|00004f20| 20 63 1b 27 4d 73 67 42 | 6f 78 20 22 64 3d 22 2b | c.'MsgB|ox "d="+|
|00004f30| 64 2e 4c 69 6e 74 74 6f | 53 74 72 69 6e 67 06 65 |d.Lintto|String.e|
|00004f40| 6e 64 20 69 66 07 70 32 | 3d 70 32 2a 32 0c 63 2e |nd if.p2|=p2*2.c.|
|00004f50| 6d 75 6c 74 69 70 6c 79 | 20 63 04 6e 65 78 74 04 |multiply| c.next.|
|00004f60| 6e 65 78 74 07 65 71 75 | 61 6c 20 64 07 45 6e 64 |next.equ|al d.End|
|00004f70| 20 53 75 62 09 72 61 6e | 64 6f 6d 69 7a 65 00 00 | Sub.ran|domize..|
|00004f80| 00 01 2f 01 2f 08 0f 53 | 75 62 20 72 61 6e 64 6f |.././..S|ub rando|
|00004f90| 6d 69 7a 65 28 29 36 52 | 45 4d 20 52 65 70 6c 61 |mize()6R|EM Repla|
|00004fa0| 63 65 20 61 20 62 79 20 | 61 20 72 61 6e 64 6f 6d |ce a by |a random|
|00004fb0| 20 6e 75 6d 62 65 72 20 | 6f 66 20 22 70 72 65 63 | number |of "prec|
|00004fc0| 69 73 69 6f 6e 22 20 64 | 69 67 69 74 73 10 44 69 |ision" d|igits.Di|
|00004fd0| 6d 20 69 20 61 73 20 69 | 6e 74 65 67 65 72 14 66 |m i as i|nteger.f|
|00004fe0| 6f 72 20 69 3d 31 20 74 | 6f 20 70 72 65 63 69 73 |or i=1 t|o precis|
|00004ff0| 69 6f 6e 19 69 61 72 72 | 61 79 28 69 29 3d 66 6c |ion.iarr|ay(i)=fl|
|00005000| 6f 6f 72 28 72 6e 64 2a | 34 30 39 36 29 04 6e 65 |oor(rnd*|4096).ne|
|00005010| 78 74 0e 6e 65 67 61 74 | 69 76 65 3d 66 61 6c 73 |xt.negat|ive=fals|
|00005020| 65 07 45 6e 64 20 53 75 | 62 09 47 65 74 4e 74 68 |e.End Su|b.GetNth|
|00005030| 42 69 74 10 69 6e 64 65 | 78 20 61 73 20 69 6e 74 |Bit.inde|x as int|
|00005040| 65 67 65 72 07 49 6e 74 | 65 67 65 72 00 02 18 02 |eger.Int|eger....|
|00005050| 18 10 2f 46 75 6e 63 74 | 69 6f 6e 20 47 65 74 4e |../Funct|ion GetN|
|00005060| 74 68 42 69 74 28 69 6e | 64 65 78 20 61 73 20 69 |thBit(in|dex as i|
|00005070| 6e 74 65 67 65 72 29 20 | 41 73 20 49 6e 74 65 67 |nteger) |As Integ|
|00005080| 65 72 20 52 45 4d 20 72 | 65 74 75 72 6e 20 74 68 |er REM r|eturn th|
|00005090| 65 20 62 69 74 20 23 22 | 69 6e 64 65 78 22 20 6f |e bit #"|index" o|
|000050a0| 66 20 61 18 52 45 4d 20 | 66 69 72 73 74 20 62 69 |f a.REM |first bi|
|000050b0| 74 20 69 73 20 69 6e 64 | 65 78 20 30 13 44 69 6d |t is ind|ex 0.Dim|
|000050c0| 20 77 6f 72 64 20 61 73 | 20 69 6e 74 65 67 65 72 | word as| integer|
|000050d0| 15 44 69 6d 20 73 75 62 | 62 69 74 20 61 73 20 69 |.Dim sub|bit as i|
|000050e0| 6e 74 65 67 65 72 12 44 | 69 6d 20 74 69 64 20 61 |nteger.D|im tid a|
|000050f0| 73 20 69 6e 74 65 67 65 | 72 0f 52 45 4d 20 66 69 |s intege|r.REM fi|
|00005100| 72 73 74 20 62 69 74 3d | 30 10 77 6f 72 64 3d 69 |rst bit=|0.word=i|
|00005110| 6e 64 65 78 5c 31 32 20 | 2b 31 13 73 75 62 62 69 |ndex\12 |+1.subbi|
|00005120| 74 3d 69 6e 64 65 78 20 | 6d 6f 64 20 31 32 2b 74 |t=index |mod 12+t|
|00005130| 69 64 3d 42 69 74 77 69 | 73 65 41 6e 64 28 69 61 |id=Bitwi|seAnd(ia|
|00005140| 72 72 61 79 28 57 6f 72 | 64 29 2c 20 50 6f 77 28 |rray(Wor|d), Pow(|
|00005150| 32 2c 73 75 62 62 69 74 | 29 29 0e 69 66 20 74 69 |2,subbit|)).if ti|
|00005160| 64 3e 30 20 74 68 65 6e | 20 08 72 65 74 75 72 6e |d>0 then| .return|
|00005170| 20 31 05 65 6c 73 65 20 | 08 72 65 74 75 72 6e 20 | 1.else |.return |
|00005180| 30 06 65 6e 64 20 69 66 | 0c 45 6e 64 20 46 75 6e |0.end if|.End Fun|
|00005190| 63 74 69 6f 6e 09 53 65 | 74 4e 74 68 42 69 74 20 |ction.Se|tNthBit |
|000051a0| 69 6e 64 65 78 20 61 73 | 20 69 6e 74 65 67 65 72 |index as| integer|
|000051b0| 2c 20 62 69 74 20 61 73 | 20 69 6e 74 65 67 65 72 |, bit as| integer|
|000051c0| 00 00 0d 00 0d 00 12 2f | 53 75 62 20 53 65 74 4e |......./|Sub SetN|
|000051d0| 74 68 42 69 74 28 69 6e | 64 65 78 20 61 73 20 69 |thBit(in|dex as i|
|000051e0| 6e 74 65 67 65 72 2c 20 | 62 69 74 20 61 73 20 69 |nteger, |bit as i|
|000051f0| 6e 74 65 67 65 72 29 13 | 44 69 6d 20 77 6f 72 64 |nteger).|Dim word|
|00005200| 20 61 73 20 69 6e 74 65 | 67 65 72 15 44 69 6d 20 | as inte|ger.Dim |
|00005210| 73 75 62 62 69 74 20 61 | 73 20 69 6e 74 65 67 65 |subbit a|s intege|
|00005220| 72 15 44 69 6d 20 62 69 | 6e 61 72 79 20 61 73 20 |r.Dim bi|nary as |
|00005230| 69 6e 74 65 67 65 72 15 | 72 65 6d 20 66 69 72 73 |integer.|rem firs|
|00005240| 74 20 62 69 74 20 69 73 | 20 7a 65 72 6f 10 77 6f |t bit is| zero.wo|
|00005250| 72 64 3d 69 6e 64 65 78 | 5c 31 32 20 2b 31 11 69 |rd=index|\12 +1.i|
|00005260| 66 20 77 6f 72 64 3e 31 | 30 32 34 20 74 68 65 6e |f word>1|024 then|
|00005270| 1a 4d 73 67 42 6f 78 20 | 22 57 6f 72 64 20 69 73 |.MsgBox |"Word is|
|00005280| 20 74 6f 6f 20 6c 61 72 | 67 65 22 06 72 65 74 75 | too lar|ge".retu|
|00005290| 72 6e 06 65 6e 64 20 69 | 66 0e 49 66 20 62 69 74 |rn.end i|f.If bit|
|000052a0| 3e 31 20 74 68 65 6e 20 | 1d 4d 73 67 42 6f 78 20 |>1 then |.MsgBox |
|000052b0| 22 62 69 74 20 69 73 20 | 6c 61 72 67 65 72 20 74 |"bit is |larger t|
|000052c0| 68 61 6e 20 31 22 06 72 | 65 74 75 72 6e 06 65 6e |han 1".r|eturn.en|
|000052d0| 64 20 69 66 13 73 75 62 | 62 69 74 3d 69 6e 64 65 |d if.sub|bit=inde|
|000052e0| 78 20 6d 6f 64 20 31 32 | 1c 62 69 6e 61 72 79 3d |x mod 12|.binary=|
|000052f0| 66 6c 6f 6f 72 28 50 6f | 77 28 32 2c 20 73 75 62 |floor(Po|w(2, sub|
|00005300| 62 69 74 29 29 3e 69 61 | 72 72 61 79 28 57 6f 72 |bit))>ia|rray(Wor|
|00005310| 64 29 3d 42 69 74 77 69 | 73 65 41 6e 64 28 69 61 |d)=Bitwi|seAnd(ia|
|00005320| 72 72 61 79 28 57 6f 72 | 64 29 2c 20 34 30 39 35 |rray(Wor|d), 4095|
|00005330| 2d 62 69 6e 61 72 79 29 | 2b 20 62 69 74 2a 62 69 |-binary)|+ bit*bi|
|00005340| 6e 61 72 79 07 45 6e 64 | 20 53 75 62 06 49 73 5a |nary.End| Sub.IsZ|
|00005350| 65 72 6f 00 07 42 6f 6f | 6c 65 61 6e 00 01 16 01 |ero..Boo|lean....|
|00005360| 16 0a 1c 46 75 6e 63 74 | 69 6f 6e 20 49 73 5a 65 |...Funct|ion IsZe|
|00005370| 72 6f 28 29 20 41 73 20 | 42 6f 6f 6c 65 61 6e 16 |ro() As |Boolean.|
|00005380| 52 45 4d 20 72 65 74 75 | 72 6e 20 74 72 75 65 20 |REM retu|rn true |
|00005390| 69 66 20 61 3d 30 10 44 | 69 6d 20 69 20 61 73 20 |if a=0.D|im i as |
|000053a0| 69 6e 74 65 67 65 72 14 | 66 6f 72 20 69 3d 31 20 |integer.|for i=1 |
|000053b0| 74 6f 20 70 72 65 63 69 | 73 69 6f 6e 13 69 66 20 |to preci|sion.if |
|000053c0| 69 61 72 72 61 79 28 69 | 29 3e 30 20 74 68 65 6e |iarray(i|)>0 then|
|000053d0| 0c 72 65 74 75 72 6e 20 | 66 61 6c 73 65 06 65 6e |.return |false.en|
|000053e0| 64 20 69 66 04 6e 65 78 | 74 0b 72 65 74 75 72 6e |d if.nex|t.return|
|000053f0| 20 74 72 75 65 0c 45 6e | 64 20 46 75 6e 63 74 69 | true.En|d Functi|
|00005400| 6f 6e 07 49 44 69 76 69 | 64 65 0f 64 65 6e 6f 20 |on.IDivi|de.deno |
|00005410| 61 73 20 69 6e 74 65 67 | 65 72 00 00 03 00 03 00 |as integ|er......|
|00005420| 13 1c 53 75 62 20 49 44 | 69 76 69 64 65 28 64 65 |..Sub ID|ivide(de|
|00005430| 6e 6f 20 61 73 20 69 6e | 74 65 67 65 72 29 16 52 |no as in|teger).R|
|00005440| 45 4d 20 63 61 6c 63 75 | 6c 61 74 65 20 61 3d 61 |EM calcu|late a=a|
|00005450| 2f 64 65 6e 6f 29 52 45 | 4d 20 64 65 6e 6f 20 6d |/deno)RE|M deno m|
|00005460| 75 73 74 20 62 65 20 61 | 20 73 6d 61 6c 6c 20 70 |ust be a| small p|
|00005470| 6f 73 69 74 69 76 65 20 | 69 6e 74 65 67 65 72 10 |ositive |integer.|
|00005480| 44 69 6d 20 69 20 61 73 | 20 69 6e 74 65 67 65 72 |Dim i as| integer|
|00005490| 19 44 69 6d 20 74 65 6d | 70 28 31 30 32 34 29 20 |.Dim tem|p(1024) |
|000054a0| 61 73 20 69 6e 74 65 67 | 65 72 10 44 69 6d 20 6d |as integ|er.Dim m|
|000054b0| 20 61 73 20 69 6e 74 65 | 67 65 72 0b 69 3d 70 72 | as inte|ger.i=pr|
|000054c0| 65 63 69 73 69 6f 6e 10 | 6d 3d 69 61 72 72 61 79 |ecision.|m=iarray|
|000054d0| 28 69 29 5c 64 65 6e 6f | 1a 69 61 72 72 61 79 28 |(i)\deno|.iarray(|
|000054e0| 69 29 3d 69 61 72 72 61 | 79 28 69 29 2d 6d 2a 64 |i)=iarra|y(i)-m*d|
|000054f0| 65 6e 6f 09 74 65 6d 70 | 28 69 29 3d 6d 1a 66 6f |eno.temp|(i)=m.fo|
|00005500| 72 20 69 3d 70 72 65 63 | 69 73 69 6f 6e 2d 31 20 |r i=prec|ision-1 |
|00005510| 64 6f 77 6e 74 6f 20 31 | 23 6d 3d 28 69 61 72 72 |downto 1|#m=(iarr|
|00005520| 61 79 28 69 2b 31 29 2a | 34 30 39 36 2b 69 61 72 |ay(i+1)*|4096+iar|
|00005530| 72 61 79 28 69 29 29 5c | 64 65 6e 6f 25 69 61 72 |ray(i))\|deno%iar|
|00005540| 72 61 79 28 69 29 3d 69 | 61 72 72 61 79 28 69 29 |ray(i)=i|array(i)|
|00005550| 2d 28 6d 2a 64 65 6e 6f | 20 6d 6f 64 20 34 30 39 |-(m*deno| mod 409|
|00005560| 36 29 09 74 65 6d 70 28 | 69 29 3d 6d 04 6e 65 78 |6).temp(|i)=m.nex|
|00005570| 74 14 66 6f 72 20 69 3d | 31 20 74 6f 20 70 72 65 |t.for i=|1 to pre|
|00005580| 63 69 73 69 6f 6e 11 69 | 61 72 72 61 79 28 69 29 |cision.i|array(i)|
|00005590| 3d 74 65 6d 70 28 69 29 | 04 6e 65 78 74 07 45 6e |=temp(i)|.next.En|
|000055a0| 64 20 53 75 62 07 49 6d | 6f 64 75 6c 6f 0f 62 61 |d Sub.Im|odulo.ba|
|000055b0| 73 65 20 61 73 20 69 6e | 74 65 67 65 72 00 00 02 |se as in|teger...|
|000055c0| 27 02 27 0e 1c 53 75 62 | 20 49 6d 6f 64 75 6c 6f |'.'..Sub| Imodulo|
|000055d0| 28 62 61 73 65 20 61 73 | 20 69 6e 74 65 67 65 72 |(base as| integer|
|000055e0| 29 1c 52 45 4d 20 63 61 | 6c 63 75 6c 61 74 65 20 |).REM ca|lculate |
|000055f0| 20 61 3d 61 20 6d 6f 64 | 75 6c 6f 20 62 20 27 52 | a=a mod|ulo b 'R|
|00005600| 45 4d 20 77 68 65 72 65 | 20 62 20 69 73 20 61 20 |EM where| b is a |
|00005610| 73 6d 61 6c 6c 20 70 6f | 73 69 74 69 76 65 20 69 |small po|sitive i|
|00005620| 6e 74 65 67 65 72 11 44 | 69 6d 20 64 20 61 73 20 |nteger.D|im d as |
|00005630| 4c 69 6e 74 65 67 65 72 | 10 44 69 6d 20 69 20 61 |Linteger|.Dim i a|
|00005640| 73 20 69 6e 74 65 67 65 | 72 0f 64 3d 20 6e 65 77 |s intege|r.d= new|
|00005650| 20 4c 69 6e 74 65 67 65 | 72 14 46 6f 72 20 69 3d | Lintege|r.For i=|
|00005660| 31 20 74 6f 20 70 72 65 | 63 69 73 69 6f 6e 15 64 |1 to pre|cision.d|
|00005670| 2e 69 61 72 72 61 79 28 | 69 29 3d 69 61 72 72 61 |.iarray(|i)=iarra|
|00005680| 79 28 69 29 04 6e 65 78 | 74 15 64 2e 70 72 65 63 |y(i).nex|t.d.prec|
|00005690| 69 73 69 6f 6e 3d 70 72 | 65 63 69 73 69 6f 6e 0e |ision=pr|ecision.|
|000056a0| 64 2e 49 44 69 76 69 64 | 65 20 62 61 73 65 10 64 |d.IDivid|e base.d|
|000056b0| 2e 49 4d 75 6c 74 69 70 | 6c 79 20 62 61 73 65 0a |.IMultip|ly base.|
|000056c0| 53 75 62 74 72 61 63 74 | 20 64 07 45 6e 64 20 53 |Subtract| d.End S|
|000056d0| 75 62 06 45 78 70 4d 6f | 64 1c 62 20 61 73 20 4c |ub.ExpMo|d.b as L|
|000056e0| 69 6e 74 65 67 65 72 2c | 20 70 20 61 73 20 4c 69 |integer,| p as Li|
|000056f0| 6e 74 65 67 65 72 00 00 | 01 00 03 00 34 28 53 75 |nteger..|....4(Su|
|00005700| 62 20 45 78 70 4d 6f 64 | 28 62 20 61 73 20 4c 69 |b ExpMod|(b as Li|
|00005710| 6e 74 65 67 65 72 2c 20 | 70 20 61 73 20 4c 69 6e |nteger, |p as Lin|
|00005720| 74 65 67 65 72 29 1d 52 | 45 4d 20 63 61 6c 63 75 |teger).R|EM calcu|
|00005730| 6c 61 74 65 20 20 61 3d | 61 5e 62 20 6d 6f 64 75 |late a=|a^b modu|
|00005740| 6c 6f 20 70 15 52 45 4d | 20 62 20 69 73 20 74 68 |lo p.REM| b is th|
|00005750| 65 20 65 78 70 6f 6e 65 | 6e 74 13 52 45 4d 20 70 |e expone|nt.REM p|
|00005760| 20 69 73 20 74 68 65 20 | 6d 6f 64 75 6c 6f 11 44 | is the |modulo.D|
|00005770| 69 6d 20 64 20 61 73 20 | 4c 69 6e 74 65 67 65 72 |im d as |Linteger|
|00005780| 11 44 69 6d 20 63 20 61 | 73 20 4c 69 6e 74 65 67 |.Dim c a|s Linteg|
|00005790| 65 72 18 44 69 6d 20 69 | 2c 6b 2c 20 6d 61 78 65 |er.Dim i|,k, maxe|
|000057a0| 20 61 73 20 69 6e 74 65 | 67 65 72 12 44 69 6d 20 | as inte|ger.Dim |
|000057b0| 62 69 74 20 61 73 20 69 | 6e 74 65 67 65 72 20 64 |bit as i|nteger d|
|000057c0| 69 6d 20 70 32 20 61 73 | 20 69 6e 74 65 67 65 72 |im p2 as| integer|
|000057d0| 20 72 65 6d 20 70 6f 77 | 65 72 20 6f 66 20 32 1b | rem pow|er of 2.|
|000057e0| 44 69 6d 20 6e 65 67 61 | 74 69 76 65 74 65 6d 70 |Dim nega|tivetemp|
|000057f0| 20 61 73 20 62 6f 6f 6c | 65 61 6e 12 69 66 20 62 | as bool|ean.if b|
|00005800| 2e 6e 65 67 61 74 69 76 | 65 20 74 68 65 6e 2b 4d |.negativ|e then+M|
|00005810| 73 67 42 6f 78 20 22 6e | 65 67 61 74 69 76 65 20 |sgBox "n|egative |
|00005820| 65 78 70 6f 6e 65 6e 74 | 73 20 6e 6f 74 20 69 6d |exponent|s not im|
|00005830| 70 6c 65 6d 65 6e 74 65 | 64 22 06 72 65 74 75 72 |plemente|d".retur|
|00005840| 6e 06 65 6e 64 20 69 66 | 15 6e 65 67 61 74 69 76 |n.end if|.negativ|
|00005850| 65 74 65 6d 70 3d 6e 65 | 67 61 74 69 76 65 0e 6e |etemp=ne|gative.n|
|00005860| 65 67 61 74 69 76 65 3d | 66 61 6c 73 65 14 69 66 |egative=|false.if|
|00005870| 20 6e 65 67 61 74 69 76 | 65 74 65 6d 70 20 74 68 | negativ|etemp th|
|00005880| 65 6e 1c 69 66 20 62 2e | 69 61 72 72 61 79 28 31 |en.if b.|iarray(1|
|00005890| 29 20 6d 6f 64 20 32 20 | 3d 30 20 74 68 65 6e 12 |) mod 2 |=0 then.|
|000058a0| 6e 65 67 61 74 69 76 65 | 74 65 6d 70 3d 66 61 6c |negative|temp=fal|
|000058b0| 73 65 06 65 6e 64 20 69 | 66 06 65 6e 64 20 69 66 |se.end i|f.end if|
|000058c0| 0f 64 3d 20 6e 65 77 20 | 4c 69 6e 74 65 67 65 72 |.d= new |Linteger|
|000058d0| 15 64 2e 70 72 65 63 69 | 73 69 6f 6e 3d 70 72 65 |.d.preci|sion=pre|
|000058e0| 63 69 73 69 6f 6e 06 64 | 2e 7a 65 72 6f 0d 64 2e |cision.d|.zero.d.|
|000058f0| 69 61 72 72 61 79 28 31 | 29 3d 31 0f 63 3d 20 6e |iarray(1|)=1.c= n|
|00005900| 65 77 20 4c 69 6e 74 65 | 67 65 72 14 46 6f 72 20 |ew Linte|ger.For |
|00005910| 69 3d 31 20 74 6f 20 70 | 72 65 63 69 73 69 6f 6e |i=1 to p|recision|
|00005920| 15 63 2e 69 61 72 72 61 | 79 28 69 29 3d 69 61 72 |.c.iarra|y(i)=iar|
|00005930| 72 61 79 28 69 29 04 6e | 65 78 74 15 63 2e 70 72 |ray(i).n|ext.c.pr|
|00005940| 65 63 69 73 69 6f 6e 3d | 70 72 65 63 69 73 69 6f |ecision=|precisio|
|00005950| 6e 0a 63 2e 6d 6f 64 75 | 6c 6f 20 70 0e 6d 61 78 |n.c.modu|lo p.max|
|00005960| 65 3d 70 72 65 63 69 73 | 69 6f 6e 21 77 68 69 6c |e=precis|ion!whil|
|00005970| 65 20 62 2e 69 61 72 72 | 61 79 28 6d 61 78 65 29 |e b.iarr|ay(maxe)|
|00005980| 3d 30 20 61 6e 64 20 6d | 61 78 65 3e 30 0b 6d 61 |=0 and m|axe>0.ma|
|00005990| 78 65 3d 6d 61 78 65 2d | 31 04 77 65 6e 64 0f 46 |xe=maxe-|1.wend.F|
|000059a0| 6f 72 20 69 3d 31 20 74 | 6f 20 6d 61 78 65 04 70 |or i=1 t|o maxe.p|
|000059b0| 32 3d 31 0d 46 6f 72 20 | 6b 3d 31 20 74 6f 20 31 |2=1.For |k=1 to 1|
|000059c0| 32 1f 62 69 74 3d 62 69 | 74 77 69 73 65 41 6e 64 |2.bit=bi|twiseAnd|
|000059d0| 28 62 2e 69 61 72 72 61 | 79 28 69 29 2c 20 70 32 |(b.iarra|y(i), p2|
|000059e0| 29 0d 49 66 20 62 69 74 | 3e 30 20 74 68 65 6e 0c |).If bit|>0 then.|
|000059f0| 64 2e 4d 75 6c 74 69 70 | 6c 79 20 63 0a 64 2e 4d |d.Multip|ly c.d.M|
|00005a00| 6f 64 75 6c 6f 20 70 1b | 27 4d 73 67 42 6f 78 20 |odulo p.|'MsgBox |
|00005a10| 22 64 3d 22 2b 64 2e 4c | 69 6e 74 74 6f 53 74 72 |"d="+d.L|inttoStr|
|00005a20| 69 6e 67 06 65 6e 64 20 | 69 66 07 70 32 3d 70 32 |ing.end |if.p2=p2|
|00005a30| 2a 32 0c 63 2e 6d 75 6c | 74 69 70 6c 79 20 63 0a |*2.c.mul|tiply c.|
|00005a40| 63 2e 6d 6f 64 75 6c 6f | 20 70 04 6e 65 78 74 04 |c.modulo| p.next.|
|00005a50| 6e 65 78 74 07 65 71 75 | 61 6c 20 64 15 6e 65 67 |next.equ|al d.neg|
|00005a60| 61 74 69 76 65 3d 6e 65 | 67 61 74 69 76 65 74 65 |ative=ne|gativete|
|00005a70| 6d 70 07 45 6e 64 20 53 | 75 62 09 44 65 63 72 65 |mp.End S|ub.Decre|
|00005a80| 6d 65 6e 74 00 00 00 03 | 39 03 39 23 0f 53 75 62 |ment....|9.9#.Sub|
|00005a90| 20 44 65 63 72 65 6d 65 | 6e 74 28 29 25 52 45 4d | Decreme|nt()%REM|
|00005aa0| 20 73 75 62 74 72 61 63 | 74 20 31 20 66 72 6f 6d | subtrac|t 1 from|
|00005ab0| 20 74 68 65 20 6c 6f 6e | 67 20 69 6e 74 65 67 65 | the lon|g intege|
|00005ac0| 72 2e 17 44 69 6d 20 69 | 2c 20 63 61 72 72 79 20 |r..Dim i|, carry |
|00005ad0| 61 73 20 69 6e 74 65 67 | 65 72 39 52 45 4d 20 69 |as integ|er9REM i|
|00005ae0| 66 20 6e 75 6d 62 65 72 | 20 69 73 20 6e 65 67 61 |f number| is nega|
|00005af0| 74 69 76 65 2c 20 74 68 | 65 6e 20 69 74 20 72 65 |tive, th|en it re|
|00005b00| 61 6c 6c 79 20 69 73 20 | 61 6e 20 69 6e 63 72 65 |ally is |an incre|
|00005b10| 6d 65 6e 74 10 49 66 20 | 6e 65 67 61 74 69 76 65 |ment.If |negative|
|00005b20| 20 74 68 65 6e 06 69 41 | 64 64 20 31 06 72 65 74 | then.iA|dd 1.ret|
|00005b30| 75 72 6e 06 65 6e 64 20 | 69 66 15 69 61 72 72 61 |urn.end |if.iarra|
|00005b40| 79 28 31 29 3d 69 61 72 | 72 61 79 28 31 29 2d 31 |y(1)=iar|ray(1)-1|
|00005b50| 14 69 66 20 20 69 61 72 | 72 61 79 28 69 29 3c 30 |.if iar|ray(i)<0|
|00005b60| 20 74 68 65 6e 07 63 61 | 72 72 79 3d 31 18 69 61 | then.ca|rry=1.ia|
|00005b70| 72 72 61 79 28 69 29 3d | 69 61 72 72 61 79 28 69 |rray(i)=|iarray(i|
|00005b80| 29 2b 34 30 39 36 05 65 | 6c 73 65 20 07 63 61 72 |)+4096.e|lse .car|
|00005b90| 72 79 3d 30 06 65 6e 64 | 20 69 66 1d 52 45 4d 20 |ry=0.end| if.REM |
|00005ba0| 63 61 6c 63 75 6c 61 74 | 65 20 74 68 65 20 63 61 |calculat|e the ca|
|00005bb0| 72 72 79 20 61 6c 6f 6e | 67 20 77 68 69 6c 65 20 |rry alon|g while |
|00005bc0| 63 61 72 72 79 20 3e 30 | 20 61 6e 64 20 69 20 3c |carry >0| and i <|
|00005bd0| 3d 70 72 65 63 69 73 69 | 6f 6e 3a 27 4d 73 67 42 |=precisi|on:'MsgB|
|00005be0| 6f 78 20 53 74 72 28 69 | 61 72 72 61 79 28 69 29 |ox Str(i|array(i)|
|00005bf0| 29 2b 22 2c 22 2b 53 74 | 72 28 62 2e 69 61 72 72 |)+","+St|r(b.iarr|
|00005c00| 61 79 28 69 29 29 2b 22 | 2c 22 2b 53 74 72 28 63 |ay(i))+"|,"+Str(c|
|00005c10| 61 72 72 79 29 19 69 61 | 72 72 61 79 28 69 29 3d |arry).ia|rray(i)=|
|00005c20| 69 61 72 72 61 79 28 69 | 29 2d 63 61 72 72 79 14 |iarray(i|)-carry.|
|00005c30| 69 66 20 20 69 61 72 72 | 61 79 28 69 29 3c 30 20 |if iarr|ay(i)<0 |
|00005c40| 74 68 65 6e 07 63 61 72 | 72 79 3d 31 18 69 61 72 |then.car|ry=1.iar|
|00005c50| 72 61 79 28 69 29 3d 69 | 61 72 72 61 79 28 69 29 |ray(i)=i|array(i)|
|00005c60| 2b 34 30 39 36 05 65 6c | 73 65 20 07 63 61 72 72 |+4096.el|se .carr|
|00005c70| 79 3d 30 06 65 6e 64 20 | 69 66 05 69 3d 69 2b 31 |y=0.end |if.i=i+1|
|00005c80| 04 77 65 6e 64 3e 52 45 | 4d 20 49 66 20 74 68 65 |.wend>RE|M If the|
|00005c90| 72 65 20 69 73 20 73 74 | 69 6c 6c 20 61 20 63 61 |re is st|ill a ca|
|00005ca0| 72 72 79 2c 20 74 68 65 | 6e 20 74 68 65 20 6e 75 |rry, the|n the nu|
|00005cb0| 6d 62 65 72 20 62 65 63 | 61 6d 65 20 6e 65 67 61 |mber bec|ame nega|
|00005cc0| 74 69 76 65 0f 52 45 4d | 20 73 6f 20 69 74 20 69 |tive.REM| so it i|
|00005cd0| 73 20 2d 31 10 69 66 20 | 63 61 72 72 79 3e 30 20 |s -1.if |carry>0 |
|00005ce0| 74 68 65 6e 20 0d 6e 65 | 67 61 74 69 76 65 3d 74 |then .ne|gative=t|
|00005cf0| 72 75 65 04 7a 65 72 6f | 07 73 65 74 20 31 2c 31 |rue.zero|.set 1,1|
|00005d00| 06 65 6e 64 20 69 66 07 | 45 6e 64 20 53 75 62 04 |.end if.|End Sub.|
|00005d10| 69 41 64 64 0c 6e 20 61 | 73 20 69 6e 74 65 67 65 |iAdd.n a|s intege|
|00005d20| 72 00 00 05 00 05 00 1a | 16 53 75 62 20 69 41 64 |r.......|.Sub iAd|
|00005d30| 64 28 6e 20 61 73 20 69 | 6e 74 65 67 65 72 29 13 |d(n as i|nteger).|
|00005d40| 52 45 4d 20 63 61 6c 63 | 75 6c 61 74 65 20 61 3d |REM calc|ulate a=|
|00005d50| 61 2b 6e 21 52 45 4d 20 | 6e 20 69 73 20 61 20 73 |a+n!REM |n is a s|
|00005d60| 6d 61 6c 6c 20 70 6f 73 | 69 74 69 76 65 20 69 6e |mall pos|itive in|
|00005d70| 74 65 67 65 72 2c 52 45 | 4d 20 41 64 64 20 69 72 |teger,RE|M Add ir|
|00005d80| 72 65 73 70 65 63 74 69 | 76 65 20 6f 66 20 73 69 |respecti|ve of si|
|00005d90| 67 6e 20 6f 66 20 6c 6f | 6e 67 20 69 6e 74 65 67 |gn of lo|ng integ|
|00005da0| 65 72 17 44 69 6d 20 69 | 2c 20 63 61 72 72 79 20 |er.Dim i|, carry |
|00005db0| 61 73 20 69 6e 74 65 67 | 65 72 15 69 61 72 72 61 |as integ|er.iarra|
|00005dc0| 79 28 31 29 3d 69 61 72 | 72 61 79 28 31 29 2b 6e |y(1)=iar|ray(1)+n|
|00005dd0| 17 69 66 20 69 61 72 72 | 61 79 28 69 29 3e 3d 34 |.if iarr|ay(i)>=4|
|00005de0| 30 39 36 20 74 68 65 6e | 07 63 61 72 72 79 3d 31 |096 then|.carry=1|
|00005df0| 18 69 61 72 72 61 79 28 | 69 29 3d 69 61 72 72 61 |.iarray(|i)=iarra|
|00005e00| 79 28 69 29 2d 34 30 39 | 36 04 65 6c 73 65 07 63 |y(i)-409|6.else.c|
|00005e10| 61 72 72 79 3d 30 06 65 | 6e 64 20 69 66 1e 77 68 |arry=0.e|nd if.wh|
|00005e20| 69 6c 65 20 63 61 72 72 | 79 3e 30 20 61 6e 64 20 |ile carr|y>0 and |
|00005e30| 69 3c 3d 70 72 65 63 69 | 73 69 6f 6e 19 69 61 72 |i<=preci|sion.iar|
|00005e40| 72 61 79 28 69 29 3d 69 | 61 72 72 61 79 28 69 29 |ray(i)=i|array(i)|
|00005e50| 2b 63 61 72 72 79 17 69 | 66 20 69 61 72 72 61 79 |+carry.i|f iarray|
|00005e60| 28 69 29 3e 3d 34 30 39 | 36 20 74 68 65 6e 07 63 |(i)>=409|6 then.c|
|00005e70| 61 72 72 79 3d 31 18 69 | 61 72 72 61 79 28 69 29 |arry=1.i|array(i)|
|00005e80| 3d 69 61 72 72 61 79 28 | 69 29 2d 34 30 39 36 04 |=iarray(|i)-4096.|
|00005e90| 65 6c 73 65 07 63 61 72 | 72 79 3d 30 06 65 6e 64 |else.car|ry=0.end|
|00005ea0| 20 69 66 05 69 3d 69 2b | 31 04 77 65 6e 64 10 69 | if.i=i+|1.wend.i|
|00005eb0| 66 20 63 61 72 72 79 3e | 30 20 74 68 65 6e 20 28 |f carry>|0 then (|
|00005ec0| 4d 73 67 42 6f 78 20 22 | 73 6d 61 6c 6c 20 69 6e |MsgBox "|small in|
|00005ed0| 74 65 67 65 72 20 61 64 | 64 69 74 69 6f 6e 20 6f |teger ad|dition o|
|00005ee0| 76 65 72 66 6c 6f 77 22 | 06 65 6e 64 20 69 66 07 |verflow"|.end if.|
|00005ef0| 45 6e 64 20 53 75 62 07 | 43 72 65 64 69 74 73 00 |End Sub.|Credits.|
|00005f00| 00 00 09 96 01 09 96 01 | 0b 0d 53 75 62 20 43 72 |........|..Sub Cr|
|00005f10| 65 64 69 74 73 28 29 31 | 52 45 4d 20 4c 69 6e 74 |edits()1|REM Lint|
|00005f20| 65 67 65 72 3a 20 61 72 | 62 69 74 72 61 72 79 20 |eger: ar|bitrary |
|00005f30| 6c 65 6e 67 74 68 20 69 | 6e 74 65 67 65 72 20 61 |length i|nteger a|
|00005f40| 72 69 74 68 6d 65 74 69 | 63 21 52 45 4d 20 43 6f |rithmeti|c!REM Co|
|00005f50| 70 79 72 69 67 68 74 20 | 50 61 73 63 61 6c 20 4d |pyright |Pascal M|
|00005f60| 65 75 6e 69 65 72 20 31 | 39 39 38 17 52 45 4d 20 |eunier 1|998.REM |
|00005f70| 61 6c 6c 20 72 69 67 68 | 74 73 20 72 65 73 65 72 |all righ|ts reser|
|00005f80| 76 65 64 13 52 45 4d 20 | a5 20 24 31 30 20 73 68 |ved.REM |. $10 sh|
|00005f90| 61 72 65 77 61 72 65 3d | 52 45 4d 20 a5 20 66 72 |areware=|REM . fr|
|00005fa0| 65 65 20 6c 69 63 65 6e | 73 65 20 66 6f 72 20 70 |ee licen|se for p|
|00005fb0| 65 72 73 6f 6e 61 6c 2c | 20 65 64 75 63 61 74 69 |ersonal,| educati|
|00005fc0| 6f 6e 61 6c 20 6f 72 20 | 66 72 65 65 77 61 72 65 |onal or |freeware|
|00005fd0| 20 75 73 65 20 a7 01 52 | 45 4d 20 a5 20 73 61 6d | use ..R|EM . sam|
|00005fe0| 65 20 6b 69 6e 64 20 65 | 78 63 68 61 6e 67 65 20 |e kind e|xchange |
|00005ff0| 6c 69 63 65 6e 73 65 20 | 66 6f 72 20 66 72 65 65 |license |for free|
|00006000| 77 61 72 65 20 6f 72 20 | 73 68 61 72 65 77 61 72 |ware or |sharewar|
|00006010| 65 20 61 75 74 68 6f 72 | 73 20 28 67 69 76 65 20 |e author|s (give |
|00006020| 6d 65 20 61 20 6c 69 63 | 65 6e 73 65 20 74 6f 20 |me a lic|ense to |
|00006030| 79 6f 75 72 20 73 6f 66 | 74 77 61 72 65 29 31 52 |your sof|tware)1R|
|00006040| 45 4d 20 a5 20 70 6c 65 | 61 73 65 20 6c 65 74 20 |EM . ple|ase let |
|00006050| 6d 65 20 6b 6e 6f 77 20 | 6f 66 20 69 6d 70 72 6f |me know |of impro|
|00006060| 76 65 6d 65 6e 74 73 20 | 79 6f 75 20 6d 61 6b 65 |vements |you make|
|00006070| 33 52 45 4d 20 20 63 6f | 6e 74 61 63 74 20 70 61 |3REM co|ntact pa|
|00006080| 73 63 61 6c 40 6b 61 67 | 69 2e 63 6f 6d 20 6f 72 |scal@kag|i.com or|
|00006090| 20 70 6d 65 75 6e 69 65 | 72 40 70 75 72 64 75 65 | pmeunie|r@purdue|
|000060a0| 2e 65 64 75 96 01 4d 73 | 67 42 6f 78 20 22 4c 69 |.edu..Ms|gBox "Li|
|000060b0| 6e 74 65 67 65 72 3a 20 | 61 72 62 69 74 72 61 72 |nteger: |arbitrar|
|000060c0| 79 20 6c 65 6e 67 74 68 | 20 69 6e 74 65 67 65 72 |y length| integer|
|000060d0| 20 61 72 69 74 68 6d 65 | 74 69 63 3b 20 20 43 6f | arithme|tic; Co|
|000060e0| 70 79 72 69 67 68 74 20 | 50 61 73 63 61 6c 20 4d |pyright |Pascal M|
|000060f0| 65 75 6e 69 65 72 20 31 | 39 39 38 22 07 45 6e 64 |eunier 1|998".End|
|00006100| 20 53 75 62 00 00 00 00 | 00 08 41 04 56 69 65 77 | Sub....|..A.View|
|00006110| 05 61 62 6f 75 74 04 9e | 06 84 03 12 04 4e 61 6d |.about..|.....Nam|
|00006120| 65 05 61 62 6f 75 74 05 | 46 72 61 6d 65 01 31 0c |e.about.|Frame.1.|
|00006130| 48 61 73 42 61 63 6b 43 | 6f 6c 6f 72 04 54 72 75 |HasBackC|olor.Tru|
|00006140| 65 09 42 61 63 6b 43 6f | 6c 6f 72 08 31 36 37 37 |e.BackCo|lor.1677|
|00006150| 37 32 31 35 08 42 61 63 | 6b 64 72 6f 70 02 31 30 |7215.Bac|kdrop.10|
|00006160| 05 54 69 74 6c 65 08 41 | 62 6f 75 74 2e 2e 2e 07 |.Title.A|bout....|
|00006170| 56 69 73 69 62 6c 65 04 | 54 72 75 65 08 43 6c 6f |Visible.|True.Clo|
|00006180| 73 65 42 6f 78 04 54 72 | 75 65 08 47 72 6f 77 49 |seBox.Tr|ue.GrowI|
|00006190| 63 6f 6e 04 54 72 75 65 | 08 5a 6f 6f 6d 49 63 6f |con.True|.ZoomIco|
|000061a0| 6e 04 54 72 75 65 0b 42 | 61 6c 6c 6f 6f 6e 48 65 |n.True.B|alloonHe|
|000061b0| 6c 70 00 09 50 6c 61 63 | 65 6d 65 6e 74 01 30 05 |lp..Plac|ement.0.|
|000061c0| 57 69 64 74 68 03 32 37 | 33 06 48 65 69 67 68 74 |Width.27|3.Height|
|000061d0| 03 34 31 38 08 4d 69 6e | 57 69 64 74 68 02 36 34 |.418.Min|Width.64|
|000061e0| 09 4d 69 6e 48 65 69 67 | 68 74 02 36 34 08 4d 61 |.MinHeig|ht.64.Ma|
|000061f0| 78 57 69 64 74 68 05 33 | 32 30 30 30 09 4d 61 78 |xWidth.3|2000.Max|
|00006200| 48 65 69 67 68 74 05 33 | 32 30 30 30 07 00 05 61 |Height.3|2000...a|
|00006210| 62 6f 75 74 98 01 06 44 | 69 61 6c 6f 67 00 00 00 |bout...D|ialog...|
|00006220| 00 01 04 4f 70 65 6e 01 | 00 01 00 03 0a 53 75 62 |...Open.|.....Sub|
|00006230| 20 4f 70 65 6e 28 29 00 | 07 45 6e 64 20 53 75 62 | Open().|.End Sub|
|00006240| 00 00 07 07 00 00 b0 01 | 0a 53 74 61 74 69 63 54 |........|.StaticT|
|00006250| 65 78 74 00 00 00 00 00 | 00 00 07 00 00 b0 01 0a |ext.....|........|
|00006260| 53 74 61 74 69 63 54 65 | 78 74 00 00 00 00 01 09 |StaticTe|xt......|
|00006270| 4d 6f 75 73 65 4d 6f 76 | 65 01 00 01 00 03 29 53 |MouseMov|e.....)S|
|00006280| 75 62 20 4d 6f 75 73 65 | 4d 6f 76 65 28 58 20 41 |ub Mouse|Move(X A|
|00006290| 73 20 49 6e 74 65 67 65 | 72 2c 20 59 20 41 73 20 |s Intege|r, Y As |
|000062a0| 49 6e 74 65 67 65 72 29 | 00 07 45 6e 64 20 53 75 |Integer)|..End Su|
|000062b0| 62 00 00 07 00 00 ac 01 | 0a 50 75 73 68 42 75 74 |b.......|.PushBut|
|000062c0| 74 6f 6e 00 00 00 00 01 | 06 41 63 74 69 6f 6e 01 |ton.....|.Action.|
|000062d0| 05 01 05 03 0c 53 75 62 | 20 41 63 74 69 6f 6e 28 |.....Sub| Action(|
|000062e0| 29 05 63 6c 6f 73 65 07 | 45 6e 64 20 53 75 62 00 |).close.|End Sub.|
|000062f0| 00 07 00 00 b0 01 0a 53 | 74 61 74 69 63 54 65 78 |.......S|taticTex|
|00006300| 74 00 00 00 00 00 00 00 | 07 00 00 b0 01 0a 53 74 |t.......|......St|
|00006310| 61 74 69 63 54 65 78 74 | 00 00 00 00 00 00 00 07 |aticText|........|
|00006320| 00 00 b0 01 0a 53 74 61 | 74 69 63 54 65 78 74 00 |.....Sta|ticText.|
|00006330| 00 00 00 00 00 00 07 00 | 00 ac 01 0a 50 75 73 68 |........|....Push|
|00006340| 42 75 74 74 6f 6e 00 00 | 00 00 01 06 41 63 74 69 |Button..|....Acti|
|00006350| 6f 6e 01 08 01 08 03 0c | 53 75 62 20 41 63 74 69 |on......|Sub Acti|
|00006360| 6f 6e 28 29 0d 6c 69 63 | 65 6e 73 65 73 2e 73 68 |on().lic|enses.sh|
|00006370| 6f 77 07 45 6e 64 20 53 | 75 62 00 00 07 0a 53 74 |ow.End S|ub....St|
|00006380| 61 74 69 63 54 65 78 74 | 17 04 4e 61 6d 65 0b 53 |aticText|..Name.S|
|00006390| 74 61 74 69 63 54 65 78 | 74 32 05 49 6e 64 65 78 |taticTex|t2.Index|
|000063a0| 0b 2d 32 31 34 37 34 38 | 33 36 34 38 0d 54 61 62 |.-214748|3648.Tab|
|000063b0| 50 61 6e 65 6c 49 6e 64 | 65 78 01 30 07 56 69 73 |PanelInd|ex.0.Vis|
|000063c0| 69 62 6c 65 04 54 72 75 | 65 04 4c 65 66 74 02 31 |ible.Tru|e.Left.1|
|000063d0| 34 03 54 6f 70 03 33 32 | 33 05 57 69 64 74 68 03 |4.Top.32|3.Width.|
|000063e0| 32 33 35 06 48 65 69 67 | 68 74 02 31 36 0b 42 61 |235.Heig|ht.16.Ba|
|000063f0| 6c 6c 6f 6f 6e 48 65 6c | 70 00 13 44 69 73 61 62 |lloonHel|p..Disab|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.